diff --git a/.github/workflows/docker.yml b/.github/workflows/docker.yml deleted file mode 100644 index d2ed337d..00000000 --- a/.github/workflows/docker.yml +++ /dev/null @@ -1,44 +0,0 @@ -name: 'docker publish' -on: - push: - branches: - - develop - -jobs: - build: - runs-on: 'ubuntu-latest' - - steps: - - name: Setup Node.js environment - uses: actions/setup-node@v3 - with: - node-version: '16' - - - name: 'Checkout Project' - uses: 'actions/checkout@v3' - with: - fetch-depth: 1 - - - name: Install Dependencies and lint code - run: yarn install && yarn lint - - - name: Test build - run: yarn build-release - - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v2 - - - name: Login to DockerHub - uses: docker/login-action@v2 - with: - username: ${{ secrets.DOCKERHUB_USERNAME }} - password: ${{ secrets.DOCKERHUB_TOKEN }} - - - name: Build docker image - uses: docker/build-push-action@v2 - with: - context: ./ - file: ./Dockerfile - builder: ${{ steps.buildx.outputs.name }} - push: true - tags: vnguyen/openbeta-graph-api:latest diff --git a/.github/workflows/nodejs.yml b/.github/workflows/nodejs.yml index 88cde9a8..e59427a7 100644 --- a/.github/workflows/nodejs.yml +++ b/.github/workflows/nodejs.yml @@ -4,25 +4,123 @@ on: push: branches: - develop + pull_request: + release: + types: [published] + jobs: - build: - runs-on: 'ubuntu-latest' + # deploy to staging by commiting to api-server-deployment repo + deploy-staging: + runs-on: ubuntu-22.04 + if: github.ref_name == 'develop' + needs: docker + steps: + - name: 'Checkout Project' + uses: 'actions/checkout@v4' + with: + fetch-depth: 1 + repository: 'openbeta/api-server-deployment' + token: ${{ secrets.GH_DEPLOYMENT_REPO_TOKEN }} + ref: main + - uses: imranismail/setup-kustomize@v2 + - run: | + cd stage + kustomize edit set image vnguyen/openbeta-graph-api:sha-${GITHUB_SHA} + - name: Check if there is any change + id: get_changes + run: echo "changed=$(git status --porcelain | wc -l)" >> $GITHUB_OUTPUT + - name: Push if tag has changes + if: steps.get_changes.outputs.changed != 0 + run: | + git config user.name github-actions + git config user.email github-actions@github.com + git commit -am "Update deployment. Code=${GITHUB_SHA}" + git push + # deploy to prod by commiting to api-server-deployment repo + deploy-prod: + runs-on: ubuntu-22.04 + if: startsWith(github.ref, 'refs/tags/v') + needs: docker steps: - - name: Setup Node.js environment - uses: actions/setup-node@v3 + - name: 'Checkout Project' + uses: 'actions/checkout@v4' with: - node-version: '16.15' + fetch-depth: 1 + repository: 'openbeta/api-server-deployment' + token: ${{ secrets.GH_DEPLOYMENT_REPO_TOKEN }} + ref: main + - uses: imranismail/setup-kustomize@v2 + - run: | + cd prod + kustomize edit set image vnguyen/openbeta-graph-api:${GITHUB_REF_NAME} + - name: Check if there is any change + id: get_changes + run: echo "changed=$(git status --porcelain | wc -l)" >> $GITHUB_OUTPUT + - name: Push if tag has changes + if: steps.get_changes.outputs.changed != 0 + run: | + git config user.name github-actions + git config user.email github-actions@github.com + git commit -am "Update deployment. Code=${GITHUB_REF_NAME}" + git push + + # build docker image and push to registry + docker: + runs-on: ubuntu-22.04 + needs: test + steps: + - name: 'Checkout Project' + uses: 'actions/checkout@v3' + with: + fetch-depth: 1 + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v2 + + - name: Login to DockerHub + uses: docker/login-action@v2 + if: github.event_name != 'pull_request' + with: + username: ${{ secrets.DOCKERHUB_USERNAME }} + password: ${{ secrets.DOCKERHUB_TOKEN }} + + - name: Docker meta + id: meta + uses: docker/metadata-action@v5 + with: + images: | + vnguyen/openbeta-graph-api + tags: | + type=ref,event=branch + type=semver,pattern={{raw}} + type=sha,format=long + + - name: Build docker image + uses: docker/build-push-action@v2 + with: + context: ./ + file: ./Dockerfile + builder: ${{ steps.buildx.outputs.name }} + push: ${{ github.event_name != 'pull_request' }} + tags: ${{ steps.meta.outputs.tags }} + # setup basic machine to run all kinds of tests: lint, unit, integration, types + test: + runs-on: 'ubuntu-22.04' + steps: - name: 'Checkout Project' uses: 'actions/checkout@v3' with: fetch-depth: 1 - - name: Install Dependencies and lint code - run: yarn install && yarn lint + - name: Setup Node.js environment + uses: actions/setup-node@v3 + with: + node-version: '16.15' + cache: 'yarn' - name: Start MongoDB uses: supercharge/mongodb-github-action@1.8.0 @@ -30,6 +128,12 @@ jobs: mongodb-version: 5 mongodb-replica-set: rs0 + - name: Install dependencies + run: yarn install --immutable + + - name: Lint code + run: yarn lint + - name: Wait for the database to start run: wget -qO- https://raw.githubusercontent.com/eficode/wait-for/$WAIT_FOR_VERSION/wait-for | sh -s -- localhost:27017 -- echo "Database is up" env: @@ -44,8 +148,8 @@ jobs: run: | docker container restart mongodb - - name: Build and run tests - run: yarn test - env: - NODE_OPTIONS: --experimental-vm-modules + - name: Run tests + run: yarn test --ci + - name: Build sources + run: yarn build-release --noEmit diff --git a/jest.config.cjs b/jest.config.cjs index ea6b6706..18bb8139 100644 --- a/jest.config.cjs +++ b/jest.config.cjs @@ -1,7 +1,18 @@ module.exports = { - preset: 'ts-jest', + moduleNameMapper: { + '^(\\.{1,2}/.*)\\.js$': '$1' + }, + extensionsToTreatAsEsm: ['.ts'], + transform: { + '^.+\\.(mt|t|cj|j)s$': [ + 'ts-jest', + { + useESM: true + } + ] + }, testEnvironment: 'node', testMatch: [ - '/build/**/__tests__/*.js' + '/**/__tests__/*.ts' ] } diff --git a/package.json b/package.json index fbbfcbde..a83b795f 100644 --- a/package.json +++ b/package.json @@ -66,7 +66,7 @@ "scripts": { "lint": "yarn ts-standard", "fix": "yarn ts-standard --fix", - "test": "yarn build && cross-env NODE_OPTIONS=\"--experimental-vm-modules\" jest --runInBand", + "test": "cross-env NODE_OPTIONS=\"--experimental-vm-modules\" jest --runInBand", "build": "tsc -p tsconfig.json", "build-release": "tsc -p tsconfig.release.json", "clean": "tsc -b --clean && rm -rf build/*", diff --git a/tsconfig.json b/tsconfig.json index 871ed609..3b503295 100644 --- a/tsconfig.json +++ b/tsconfig.json @@ -10,7 +10,6 @@ "module": "ESNext", "esModuleInterop": true, "moduleResolution": "Node", - "rootDir": "./src", "outDir": "build", "sourceMap": true, "strictNullChecks": true, @@ -21,4 +20,4 @@ "include": [ "src/**/*.ts", ] -} \ No newline at end of file +}