From f05114a8e6f437262f16328d2255d2835f2ca4bf Mon Sep 17 00:00:00 2001
From: Kalin Daskalov <kalin.daskalov@vereign.com>
Date: Thu, 2 Nov 2023 09:32:42 +0200
Subject: [PATCH] add submodule and ci

---
 .gitlab-ci.yml | 84 +++++++++++++++++++++++++++++++++++++++++++++-----
 .gitmodules    |  3 ++
 app            |  1 +
 3 files changed, 81 insertions(+), 7 deletions(-)
 create mode 100644 .gitmodules
 create mode 160000 app

diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml
index 35ea347..1e24d21 100644
--- a/.gitlab-ci.yml
+++ b/.gitlab-ci.yml
@@ -1,24 +1,94 @@
+---
 variables:
-  HELPERS_FILE: helm-package.yml
-
-image: $HELM_IMAGE
-
-include:
-  - project: '${HELPERS_PATH}'
-    file: '${HELPERS_FILE}'
+  HELPERS_FILE: build-eclipse.yml
+  HELM_HELPERS_FILE: helm-eclipse.yml
+  APP_HELM_NAME: cache
+  DOCKER_FILE: app/deployment/ci/Dockerfile
 
 stages:
+  - test
+  - build
+  - manifest
   - lint
   - package
+  - deploy
+
+include:
+  - project: "${HELPERS_PATH}"
+    file: 'build-eclipse.yml'
+  - template: "Workflows/Branch-Pipelines.gitlab-ci.yml"
+  - project: "${HELPERS_PATH}"
+    file: 'helm-eclipse.yml'
+
+
+lint:
+  image: golangci/golangci-lint:latest
+  stage: test
+  tags:
+    - amd64-docker
+  script:
+    - golangci-lint --version
+    - golangci-lint run
+  before_script:
+    - ln -s /builds /go/src/gitlab.com
+    - cd /go/src/gitlab.com/${CI_PROJECT_PATH}/app
+
+unit tests:
+  image: golang:1.21.3
+  stage: test
+  tags:
+    - amd64-docker
+  script:
+    - go version
+    - go test $(go list ./... | grep -v /integration) -race -coverprofile=coverage.out
+    - go tool cover -func=coverage.out
+  before_script:
+    - ln -s /builds /go/src/gitlab.com
+    - cd /go/src/gitlab.com/${CI_PROJECT_PATH}/app
+  coverage: '/total:\s+\(statements\)\s+(\d+.\d+\%)/'
+
+govulncheck:
+  image: golang:1.21.3
+  stage: test
+  tags:
+    - amd64-docker
+  before_script:
+    - ln -s /builds /go/src/gitlab.com
+    - cd /go/src/gitlab.com/${CI_PROJECT_PATH}/app
+  script:
+    - go version
+    - go install golang.org/x/vuln/cmd/govulncheck@latest
+    - govulncheck ./...
+
+amd64:
+  extends: .docker-build
+  stage: build
+  tags:
+    - amd64-docker
+
+manifest:
+  extends: .manifest-amd64
+  stage: manifest
+
+cloud:
+  extends: .manifest-cloud
+  stage: manifest
+
+release:
+  extends: .manifest-release
+  stage: manifest
 
 helm-lint:
+  image: ${HELM_IMAGE}
   extends: .helm-lint
   stage: lint
   tags:
     - amd64-docker
 
 helm-package:
+  image: ${HELM_IMAGE}
   extends: .helm-package
   stage: package
   tags:
     - amd64-docker
+  needs: ["helm-lint"]
diff --git a/.gitmodules b/.gitmodules
new file mode 100644
index 0000000..7be0d2d
--- /dev/null
+++ b/.gitmodules
@@ -0,0 +1,3 @@
+[submodule "app"]
+	path = app
+	url = https://gitlab.eclipse.org/eclipse/xfsc/tsa/cache.git
diff --git a/app b/app
new file mode 160000
index 0000000..127b4ae
--- /dev/null
+++ b/app
@@ -0,0 +1 @@
+Subproject commit 127b4ae5eb0d105803afc87112e881c5f0eb8921
-- 
GitLab