aboutsummaryrefslogtreecommitdiff
path: root/.github/workflows/benchmarks.yml
blob: e40abf2f6250d97b875f2cd9d13138e0dba3b816 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
name: Benchmarks

on:
  schedule:
    - cron: '0 8 * * *'
  workflow_dispatch:

jobs:
  Benchmark:
    name: ${{ matrix.config.task-name }}
    runs-on: ubuntu-latest
    timeout-minutes: 30
    strategy:
      fail-fast: false
      matrix:
        config:
          - python-version: "3.10"
            task: "tests/challenges"
            task-name: "Mandatory Tasks"
          - python-version: "3.10"
            task: "--beat-challenges -ra tests/challenges"
            task-name: "Challenging Tasks"

    steps:
      - name: Checkout repository
        uses: actions/checkout@v3
        with:
          ref: master

      - name: Set up Python ${{ matrix.python-version }}
        uses: actions/setup-python@v2
        with:
          python-version: ${{ matrix.config.python-version }}

      - id: get_date
        name: Get date
        run: echo "date=$(date +'%Y-%m-%d')" >> $GITHUB_OUTPUT

      - name: Set up Python dependency cache
        uses: actions/cache@v3
        with:
          path: ~/.cache/pip
          key: ${{ runner.os }}-pip-${{ hashFiles('**/requirements.txt') }}-${{ steps.get_date.outputs.date }}

      - name: Install Python dependencies
        run: |
          python -m pip install --upgrade pip
          pip install -r requirements.txt

      - name: Run pytest with coverage
        run: |
          rm -rf tests/Auto-GPT-test-cassettes
          pytest -n auto --record-mode=all ${{ matrix.config.task }}
        env:
          CI: true
          PROXY: ${{ secrets.PROXY }}
          AGENT_MODE: ${{ secrets.AGENT_MODE }}
          AGENT_TYPE: ${{ secrets.AGENT_TYPE }}
          PLAIN_OUTPUT: True

      - name: Upload logs as artifact
        if: always()
        uses: actions/upload-artifact@v3
        with:
          name: test-logs-${{ matrix.config.task-name }}
          path: logs/

      - name: Upload cassettes as artifact
        if: always()
        uses: actions/upload-artifact@v3
        with:
          name: cassettes-${{ matrix.config.task-name }}
          path: tests/Auto-GPT-test-cassettes/