name: Test (backend) on: push: branches: - io paths: - packages/backend/** # for permissions - packages/misskey-js/** pull_request: paths: - packages/backend/** # for permissions - packages/misskey-js/** jobs: unit: runs-on: ubuntu-latest strategy: matrix: node-version: [20.x] services: postgres: image: postgres:15 ports: - 54312:5432 env: POSTGRES_DB: test-misskey POSTGRES_HOST_AUTH_METHOD: trust keydb: image: eqalpha/keydb:latest ports: - 56312:6379 steps: - uses: actions/checkout@v4.1.1 with: submodules: true - name: Install pnpm uses: pnpm/action-setup@v2 with: version: 8 run_install: false - name: Use Node.js ${{ matrix.node-version }} uses: actions/setup-node@v4.0.1 with: node-version: ${{ matrix.node-version }} cache: 'pnpm' - run: corepack enable - run: pnpm i --frozen-lockfile - name: Check pnpm-lock.yaml run: git diff --exit-code pnpm-lock.yaml - name: Copy Configure run: cp .github/misskey/test.yml .config - name: Build run: pnpm build - name: Test run: pnpm --filter backend test-and-coverage - name: Upload to Codecov uses: codecov/codecov-action@v4 with: token: ${{ secrets.CODECOV_TOKEN }} files: ./packages/backend/coverage/coverage-final.json e2e: runs-on: ubuntu-latest strategy: matrix: node-version: [20.x] services: postgres: image: postgres:15 ports: - 54312:5432 env: POSTGRES_DB: test-misskey POSTGRES_HOST_AUTH_METHOD: trust keydb: image: eqalpha/keydb:latest ports: - 56312:6379 steps: - uses: actions/checkout@v4.1.1 with: submodules: true - name: Install pnpm uses: pnpm/action-setup@v2 with: version: 8 run_install: false - name: Use Node.js ${{ matrix.node-version }} uses: actions/setup-node@v4.0.1 with: node-version: ${{ matrix.node-version }} cache: 'pnpm' - run: corepack enable - run: pnpm i --frozen-lockfile - name: Check pnpm-lock.yaml run: git diff --exit-code pnpm-lock.yaml - name: Copy Configure run: cp .github/misskey/test.yml .config - name: Build run: pnpm build - name: Test run: pnpm --filter backend test-and-coverage:e2e - name: Upload to Codecov uses: codecov/codecov-action@v4 with: token: ${{ secrets.CODECOV_TOKEN }} files: ./packages/backend/coverage/coverage-final.json