|
2 | 2 | # Tests are parallelized to run faster by splitting them into separate jobs that run concurrently |
3 | 3 | # |
4 | 4 | # See the workflow visualization in knowledge file |
5 | | -# ``` |
6 | 5 |
|
7 | 6 | name: CI |
8 | 7 |
|
|
12 | 11 | pull_request: |
13 | 12 | branches: ['main'] |
14 | 13 |
|
15 | | -env: |
16 | | - CODEBUFF_GITHUB_ACTIONS: 'true' |
17 | | - NEXT_PUBLIC_CB_ENVIRONMENT: 'local' |
18 | | - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} |
19 | | - |
20 | 14 | # Define reusable job template |
21 | 15 | jobs: |
22 | 16 | build: |
@@ -44,14 +38,28 @@ jobs: |
44 | 38 | - name: Install dependencies |
45 | 39 | run: bun install --frozen-lockfile |
46 | 40 |
|
47 | | - - name: Set Environment Variables |
| 41 | + - name: Set environment variables |
| 42 | + env: |
| 43 | + SECRETS_CONTEXT: ${{ toJSON(secrets) }} |
48 | 44 | run: | |
49 | | - echo "${{ secrets.ENV_LOCAL }}" > .env.local |
| 45 | + VAR_NAMES=$(node scripts/generate-ci-env.js) |
| 46 | + echo "$SECRETS_CONTEXT" | jq -r --argjson vars "$VAR_NAMES" ' |
| 47 | + to_entries | .[] | select(.key as $k | $vars | index($k)) | .key + "=" + .value |
| 48 | + ' >> $GITHUB_ENV |
| 49 | + echo "CODEBUFF_GITHUB_ACTIONS=true" >> $GITHUB_ENV |
| 50 | + echo "NEXT_PUBLIC_CB_ENVIRONMENT=test" >> $GITHUB_ENV |
| 51 | + echo "NEXT_PUBLIC_INFISICAL_UP=true" >> $GITHUB_ENV |
| 52 | + echo "CODEBUFF_GITHUB_TOKEN=${{ secrets.CODEBUFF_GITHUB_TOKEN }}" >> $GITHUB_ENV |
50 | 53 |
|
51 | 54 | - name: Build and typecheck |
52 | 55 | run: | |
53 | 56 | bun run build |
54 | 57 |
|
| 58 | + # - name: Open interactive debug shell |
| 59 | + # if: ${{ failure() }} |
| 60 | + # uses: mxschmitt/action-tmate@v3 |
| 61 | + # timeout-minutes: 15 # optional guard |
| 62 | + |
55 | 63 | # Template for test jobs |
56 | 64 | test: |
57 | 65 | needs: build |
@@ -87,18 +95,87 @@ jobs: |
87 | 95 | - name: Install dependencies |
88 | 96 | run: bun install --frozen-lockfile |
89 | 97 |
|
90 | | - - name: Set Environment Variables |
| 98 | + - name: Set environment variables |
| 99 | + env: |
| 100 | + SECRETS_CONTEXT: ${{ toJSON(secrets) }} |
91 | 101 | run: | |
92 | | - echo "${{ secrets.ENV_LOCAL }}" > .env.local |
| 102 | + VAR_NAMES=$(node scripts/generate-ci-env.js) |
| 103 | + echo "$SECRETS_CONTEXT" | jq -r --argjson vars "$VAR_NAMES" ' |
| 104 | + to_entries | .[] | select(.key as $k | $vars | index($k)) | .key + "=" + .value |
| 105 | + ' >> $GITHUB_ENV |
| 106 | + echo "CODEBUFF_GITHUB_ACTIONS=true" >> $GITHUB_ENV |
| 107 | + echo "NEXT_PUBLIC_CB_ENVIRONMENT=test" >> $GITHUB_ENV |
| 108 | + echo "NEXT_PUBLIC_INFISICAL_UP=true" >> $GITHUB_ENV |
| 109 | + echo "CODEBUFF_GITHUB_TOKEN=${{ secrets.CODEBUFF_GITHUB_TOKEN }}" >> $GITHUB_ENV |
93 | 110 |
|
94 | 111 | - name: Run ${{ matrix.package }} tests |
95 | 112 | uses: nick-fields/retry@v3 |
96 | 113 | with: |
97 | 114 | timeout_minutes: 10 |
98 | 115 | max_attempts: 5 |
99 | | - command: cd ${{ matrix.package }} && bun test $(find src -name *.test.ts) |
| 116 | + command: cd ${{ matrix.package }} && bun test $(find src -name '*.test.ts' ! -name '*.integration.test.ts') |
100 | 117 |
|
101 | 118 | # - name: Open interactive debug shell |
102 | 119 | # if: ${{ failure() }} |
103 | 120 | # uses: mxschmitt/action-tmate@v3 |
104 | 121 | # timeout-minutes: 15 # optional guard |
| 122 | + |
| 123 | + # Template for test jobs |
| 124 | + # test-integration: |
| 125 | + # needs: build |
| 126 | + # strategy: |
| 127 | + # matrix: |
| 128 | + # package: [npm-app, backend, common] |
| 129 | + # include: |
| 130 | + # - package: npm-app |
| 131 | + # - package: backend |
| 132 | + # - package: common |
| 133 | + # name: test-integration-${{ matrix.package }} |
| 134 | + # runs-on: ubuntu-latest |
| 135 | + # steps: |
| 136 | + # - name: Checkout repository |
| 137 | + # uses: actions/checkout@v3 |
| 138 | + |
| 139 | + # - name: Set up Bun |
| 140 | + # uses: oven-sh/setup-bun@v2 |
| 141 | + # with: |
| 142 | + # bun-version: '1.2.12' |
| 143 | + |
| 144 | + # - name: Cache dependencies |
| 145 | + # uses: actions/cache@v3 |
| 146 | + # with: |
| 147 | + # path: | |
| 148 | + # node_modules |
| 149 | + # */node_modules |
| 150 | + # packages/*/node_modules |
| 151 | + # key: ${{ runner.os }}-deps-${{ hashFiles('**/bun.lockb') }} |
| 152 | + # restore-keys: | |
| 153 | + # ${{ runner.os }}-deps- |
| 154 | + |
| 155 | + # - name: Install dependencies |
| 156 | + # run: bun install --frozen-lockfile |
| 157 | + |
| 158 | + # - name: Set environment variables |
| 159 | + # env: |
| 160 | + # SECRETS_CONTEXT: ${{ toJSON(secrets) }} |
| 161 | + # run: | |
| 162 | + # VAR_NAMES=$(node scripts/generate-ci-env.js) |
| 163 | + # echo "$SECRETS_CONTEXT" | jq -r --argjson vars "$VAR_NAMES" ' |
| 164 | + # to_entries | .[] | select(.key as $k | $vars | index($k)) | .key + "=" + .value |
| 165 | + # ' >> $GITHUB_ENV |
| 166 | + # echo "CODEBUFF_GITHUB_ACTIONS=true" >> $GITHUB_ENV |
| 167 | + # echo "NEXT_PUBLIC_CB_ENVIRONMENT=test" >> $GITHUB_ENV |
| 168 | + # echo "NEXT_PUBLIC_INFISICAL_UP=true" >> $GITHUB_ENV |
| 169 | + # echo "CODEBUFF_GITHUB_TOKEN=${{ secrets.CODEBUFF_GITHUB_TOKEN }}" >> $GITHUB_ENV |
| 170 | + |
| 171 | + # - name: Run ${{ matrix.package }} tests |
| 172 | + # uses: nick-fields/retry@v3 |
| 173 | + # with: |
| 174 | + # timeout_minutes: 10 |
| 175 | + # max_attempts: 5 |
| 176 | + # command: cd ${{ matrix.package }} && bun test $(find src -name '*.integration.test.ts') |
| 177 | + |
| 178 | + # # - name: Open interactive debug shell |
| 179 | + # # if: ${{ failure() }} |
| 180 | + # # uses: mxschmitt/action-tmate@v3 |
| 181 | + # # timeout-minutes: 15 # optional guard |
0 commit comments