config.yml 41.7 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
version: 2.1
orbs:
    gcp-gke: circleci/gcp-gke@1.0.4
    go: circleci/go@1.3.0

# TPU REFERENCES
references:
    checkout_ml_testing: &checkout_ml_testing
        run:
            name: Checkout ml-testing-accelerators
            command: |
                git clone https://github.com/GoogleCloudPlatform/ml-testing-accelerators.git
                cd ml-testing-accelerators
                git fetch origin 5e88ac24f631c27045e62f0e8d5dfcf34e425e25:stable
                git checkout stable
    build_push_docker: &build_push_docker
        run:
            name: Configure Docker
            command: |
                gcloud --quiet auth configure-docker
                cd docker/transformers-pytorch-tpu
22
                if [ -z "$CIRCLE_PR_NUMBER" ]; then docker build --tag "$GCR_IMAGE_PATH:$CIRCLE_WORKFLOW_JOB_ID" -f Dockerfile --build-arg "TEST_IMAGE=1" . ; else docker build --tag "$GCR_IMAGE_PATH:$CIRCLE_WORKFLOW_JOB_ID" -f Dockerfile --build-arg "TEST_IMAGE=1" --build-arg "GITHUB_REF=pull/$CIRCLE_PR_NUMBER/head" . ; fi
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
                docker push "$GCR_IMAGE_PATH:$CIRCLE_WORKFLOW_JOB_ID"
    deploy_cluster: &deploy_cluster
        run:
            name: Deploy the job on the kubernetes cluster
            command: |
                go get github.com/google/go-jsonnet/cmd/jsonnet && \
                export PATH=$PATH:$HOME/go/bin && \
                kubectl create -f docker/transformers-pytorch-tpu/dataset.yaml || true && \
                job_name=$(jsonnet -J ml-testing-accelerators/ docker/transformers-pytorch-tpu/bert-base-cased.jsonnet --ext-str image=$GCR_IMAGE_PATH --ext-str image-tag=$CIRCLE_WORKFLOW_JOB_ID | kubectl create -f -) && \
                job_name=${job_name#job.batch/} && \
                job_name=${job_name% created} && \
                echo "Waiting on kubernetes job: $job_name" && \
                i=0 && \
                # 30 checks spaced 30s apart = 900s total.
                max_checks=30 && \
                status_code=2 && \
                # Check on the job periodically. Set the status code depending on what
                # happened to the job in Kubernetes. If we try max_checks times and
                # still the job hasn't finished, give up and return the starting
                # non-zero status code.
                while [ $i -lt $max_checks ]; do ((i++)); if kubectl get jobs $job_name -o jsonpath='Failed:{.status.failed}' | grep "Failed:1"; then status_code=1 && break; elif kubectl get jobs $job_name -o jsonpath='Succeeded:{.status.succeeded}' | grep "Succeeded:1" ; then status_code=0 && break; else echo "Job not finished yet"; fi; sleep 30; done && \
                echo "Done waiting. Job status code: $status_code" && \
45
46
47
                pod_name=$(kubectl get po -l controller-uid=`kubectl get job $job_name -o "jsonpath={.metadata.labels.controller-uid}"` | awk 'match($0,!/NAME/) {print $1}') && \
                echo "GKE pod name: $pod_name" && \
                kubectl logs -f $pod_name --container=train
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
                echo "Done with log retrieval attempt." && \
                gcloud container images delete "$GCR_IMAGE_PATH:$CIRCLE_WORKFLOW_JOB_ID" --force-delete-tags && \
                exit $status_code
    delete_gke_jobs: &delete_gke_jobs
        run:
            name: Delete GKE Jobs
            command: |
                # Match jobs whose age matches patterns like '1h' or '1d', i.e. any job
                # that has been around longer than 1hr. First print all columns for
                # matches, then execute the delete.
                kubectl get job | awk 'match($4,/[0-9]+[dh]/) {print $0}'
                kubectl delete job $(kubectl get job | awk 'match($4,/[0-9]+[dh]/) {print $1}')




Julien Chaumond's avatar
Julien Chaumond committed
64
jobs:
Aymeric Augustin's avatar
Aymeric Augustin committed
65
    run_tests_torch_and_tf:
66
        working_directory: ~/transformers
67
        docker:
Kamal Raj's avatar
Kamal Raj committed
68
            - image: circleci/python:3.7
69
70
        environment:
            OMP_NUM_THREADS: 1
71
72
            RUN_PT_TF_CROSS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
73
74
75
76
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
77
78
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
79
80
                      - v0.4-torch_and_tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
81
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
82
            - run: pip install --upgrade pip
83
            - run: pip install .[sklearn,tf-cpu,torch,testing,sentencepiece,torch-speech,vision]
84
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
Kamal Raj's avatar
Kamal Raj committed
85
            - run: pip install tensorflow_probability
86
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
87
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
88
                key: v0.4-{{ checksum "setup.py" }}
89
90
                paths:
                    - '~/.cache/pip'
91
92
93
94
95
96
97
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_torch_and_tf $(cat test_list.txt) -m is_pt_tf_cross_test --durations=0 | tee tests_output.txt
                  fi
98
            - store_artifacts:
99
100
101
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
102

103
104
105
    run_tests_torch_and_tf_all:
        working_directory: ~/transformers
        docker:
106
            - image: circleci/python:3.7
107
108
109
110
111
112
113
114
115
116
117
118
        environment:
            OMP_NUM_THREADS: 1
            RUN_PT_TF_CROSS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch_and_tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
119
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
120
            - run: pip install --upgrade pip
121
            - run: pip install .[sklearn,tf-cpu,torch,testing,sentencepiece,torch-speech,vision]
122
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
Kamal Raj's avatar
Kamal Raj committed
123
            - run: pip install tensorflow_probability
124
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
125
126
127
128
129
130
131
132
133
134
            - save_cache:
                key: v0.4-{{ checksum "setup.py" }}
                paths:
                    - '~/.cache/pip'
            - run: |
                  python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_torch_and_tf tests -m is_pt_tf_cross_test --durations=0 | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
135

136
137
138
    run_tests_torch_and_flax:
        working_directory: ~/transformers
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
139
            - image: circleci/python:3.7
140
141
        environment:
            OMP_NUM_THREADS: 1
142
143
            RUN_PT_FLAX_CROSS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
144
145
146
147
148
149
150
151
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch_and_flax-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
152
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
153
            - run: pip install --upgrade pip
154
            - run: pip install .[sklearn,flax,torch,testing,sentencepiece,torch-speech,vision]
155
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
156
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
157
158
159
160
            - save_cache:
                key: v0.4-{{ checksum "setup.py" }}
                paths:
                    - '~/.cache/pip'
161
162
163
164
165
166
167
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_torch_and_flax $(cat test_list.txt) -m is_pt_flax_cross_test --durations=0 | tee tests_output.txt
                  fi
168
169
170
171
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
172

173
174
175
    run_tests_torch_and_flax_all:
        working_directory: ~/transformers
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
176
            - image: circleci/python:3.7
177
178
179
180
181
182
183
184
185
186
187
188
        environment:
            OMP_NUM_THREADS: 1
            RUN_PT_FLAX_CROSS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch_and_flax-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
189
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
190
            - run: pip install --upgrade pip
191
            - run: pip install .[sklearn,flax,torch,testing,sentencepiece,torch-speech,vision]
192
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
193
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
194
195
196
197
198
199
200
201
202
203
            - save_cache:
                key: v0.4-{{ checksum "setup.py" }}
                paths:
                    - '~/.cache/pip'
            - run: |
                  python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_torch_and_flax tests -m is_pt_flax_cross_test --durations=0 | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
204

Aymeric Augustin's avatar
Aymeric Augustin committed
205
    run_tests_torch:
206
        working_directory: ~/transformers
Julien Chaumond's avatar
Julien Chaumond committed
207
        docker:
208
            - image: circleci/python:3.7
209
210
        environment:
            OMP_NUM_THREADS: 1
211
            TRANSFORMERS_IS_CI: yes
212
        resource_class: xlarge
213
        parallelism: 1
Julien Chaumond's avatar
Julien Chaumond committed
214
215
        steps:
            - checkout
216
217
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
218
219
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
220
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng time
221
            - run: pip install --upgrade pip
222
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
223
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
224
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
225
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
226
                  key: v0.4-torch-{{ checksum "setup.py" }}
227
228
                  paths:
                      - '~/.cache/pip'
229
230
231
232
233
234
235
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 3 --dist=loadfile -s --make-reports=tests_torch $(cat test_list.txt) | tee tests_output.txt
                  fi
236
            - store_artifacts:
237
238
239
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
240

241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
    run_tests_torch_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
256
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
257
            - run: pip install --upgrade pip
258
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
259
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
260
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
261
262
263
264
265
266
267
268
269
270
            - save_cache:
                  key: v0.4-torch-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  python -m pytest -n 3 --dist=loadfile -s --make-reports=tests_torch tests | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
Lysandre Debut's avatar
Lysandre Debut committed
271

Aymeric Augustin's avatar
Aymeric Augustin committed
272
    run_tests_tf:
273
        working_directory: ~/transformers
thomwolf's avatar
thomwolf committed
274
        docker:
275
            - image: circleci/python:3.7
276
277
        environment:
            OMP_NUM_THREADS: 1
278
            TRANSFORMERS_IS_CI: yes
thomwolf's avatar
thomwolf committed
279
280
281
282
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
283
284
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
285
286
                      - v0.4-tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
287
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
288
            - run: pip install --upgrade pip
289
            - run: pip install .[sklearn,tf-cpu,testing,sentencepiece,tf-speech,vision]
Kamal Raj's avatar
Kamal Raj committed
290
            - run: pip install tensorflow_probability
291
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
292
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
293
                  key: v0.4-tf-{{ checksum "setup.py" }}
294
295
                  paths:
                      - '~/.cache/pip'
296
297
298
299
300
301
302
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_tf $(cat test_list.txt) | tee tests_output.txt
                  fi
303
            - store_artifacts:
304
305
306
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
307

308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
    run_tests_tf_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
323
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
324
            - run: pip install --upgrade pip
325
            - run: pip install .[sklearn,tf-cpu,testing,sentencepiece,tf-speech,vision]
Kamal Raj's avatar
Kamal Raj committed
326
            - run: pip install tensorflow_probability
327
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
328
329
330
331
332
333
334
335
336
337
            - save_cache:
                  key: v0.4-tf-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_tf tests | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
338

339
340
341
342
343
344
    run_tests_flax:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
345
            TRANSFORMERS_IS_CI: yes
346
347
348
349
350
351
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                keys:
Lysandre Debut's avatar
Lysandre Debut committed
352
353
                    - v0.4-flax-{{ checksum "setup.py" }}
                    - v0.4-{{ checksum "setup.py" }}
354
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
355
            - run: pip install --upgrade pip
356
357
            - run: pip install .[flax,testing,sentencepiece,flax-speech,vision]
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
358
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
359
                  key: v0.4-flax-{{ checksum "setup.py" }}
360
361
                  paths:
                      - '~/.cache/pip'
362
363
364
365
366
367
368
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_flax $(cat test_list.txt) | tee tests_output.txt
                  fi
369
            - store_artifacts:
370
371
372
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
373

374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
    run_tests_flax_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                keys:
                    - v0.4-flax-{{ checksum "setup.py" }}
                    - v0.4-{{ checksum "setup.py" }}
389
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
390
            - run: pip install --upgrade pip
391
392
            - run: pip install .[flax,testing,sentencepiece,vision,flax-speech]
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
393
394
395
396
397
398
399
400
401
402
            - save_cache:
                  key: v0.4-flax-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_flax tests | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
403

404
405
406
407
408
409
    run_tests_pipelines_torch:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
410
411
            RUN_PIPELINE_TESTS: yes
            TRANSFORMERS_IS_CI: yes
412
413
414
415
416
417
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
418
419
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
420
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
421
            - run: pip install --upgrade pip
422
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
423
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
424
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
425
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
426
                  key: v0.4-torch-{{ checksum "setup.py" }}
427
428
                  paths:
                      - '~/.cache/pip'
429
430
431
432
433
434
435
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_pipelines_torch -m is_pipeline_test $(cat test_list.txt) | tee tests_output.txt
                  fi
436
            - store_artifacts:
437
438
439
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
440

441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
    run_tests_pipelines_torch_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            RUN_PIPELINE_TESTS: yes
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
457
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
458
            - run: pip install --upgrade pip
459
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
460
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.11.0+cpu.html
461
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
462
463
464
465
466
467
468
469
470
471
            - save_cache:
                  key: v0.4-torch-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_pipelines_torch -m is_pipeline_test tests | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
472

473
474
475
476
477
478
    run_tests_pipelines_tf:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
479
480
            RUN_PIPELINE_TESTS: yes
            TRANSFORMERS_IS_CI: yes
481
482
483
484
485
486
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
487
488
                      - v0.4-tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
489
            - run: pip install --upgrade pip
490
            - run: pip install .[sklearn,tf-cpu,testing,sentencepiece]
Kamal Raj's avatar
Kamal Raj committed
491
            - run: pip install tensorflow_probability
492
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
493
                  key: v0.4-tf-{{ checksum "setup.py" }}
494
495
                  paths:
                      - '~/.cache/pip'
496
497
498
499
500
501
502
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_pipelines_tf $(cat test_list.txt) -m is_pipeline_test | tee tests_output.txt
                  fi
503
504
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
505
            - store_artifacts:
506
507
                  path: ~/transformers/reports

508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
    run_tests_pipelines_tf_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            RUN_PIPELINE_TESTS: yes
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
            - run: pip install --upgrade pip
            - run: pip install .[sklearn,tf-cpu,testing,sentencepiece]
Kamal Raj's avatar
Kamal Raj committed
526
            - run: pip install tensorflow_probability
527
528
529
530
531
            - save_cache:
                  key: v0.4-tf-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
532
                  python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_pipelines_tf tests -m is_pipeline_test | tee tests_output.txt
533
534
535
536
537
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports

Aymeric Augustin's avatar
Aymeric Augustin committed
538
    run_tests_custom_tokenizers:
539
540
        working_directory: ~/transformers
        docker:
541
            - image: circleci/python:3.7
542
543
        environment:
            RUN_CUSTOM_TOKENIZERS: yes
544
            TRANSFORMERS_IS_CI: yes
545
546
        steps:
            - checkout
547
548
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
549
550
                      - v0.4-custom_tokenizers-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
551
            - run: pip install --upgrade pip
552
            - run: pip install .[ja,testing,sentencepiece,jieba,spacy,ftfy,rjieba]
553
            - run: python -m unidic download
554
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
555
                  key: v0.4-custom_tokenizers-{{ checksum "setup.py" }}
556
557
                  paths:
                      - '~/.cache/pip'
558
559
            - run: |
                  if [ -f test_list.txt ]; then
560
                    python -m pytest -s --make-reports=tests_custom_tokenizers ./tests/test_tokenization_bert_japanese.py ./tests/test_tokenization_openai.py | tee tests_output.txt
561
                  fi
562
563
564
565
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 1 tests/test_tokenization_clip.py --dist=loadfile -s --make-reports=tests_tokenization_clip --durations=100 | tee tests_output.txt
                  fi
566
567
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
568
            - store_artifacts:
569
570
                  path: ~/transformers/reports

Aymeric Augustin's avatar
Aymeric Augustin committed
571
    run_examples_torch:
572
573
        working_directory: ~/transformers
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
574
            - image: circleci/python:3.7
575
576
        environment:
            OMP_NUM_THREADS: 1
577
            TRANSFORMERS_IS_CI: yes
578
579
580
581
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
582
583
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
584
585
                      - v0.4-torch_examples-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
586
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
587
            - run: pip install --upgrade pip
588
            - run: pip install .[sklearn,torch,sentencepiece,testing,torch-speech]
Sylvain Gugger's avatar
Sylvain Gugger committed
589
            - run: pip install -r examples/pytorch/_tests_requirements.txt
590
            - run: pip install git+https://github.com/huggingface/accelerate
591
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
592
                  key: v0.4-torch_examples-{{ checksum "setup.py" }}
593
594
                  paths:
                      - '~/.cache/pip'
595
            - run: python utils/tests_fetcher.py --filters examples tests | tee test_preparation.txt
596
597
598
599
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
600
                    python -m pytest -n 8 --dist=loadfile -s --make-reports=examples_torch ./examples/pytorch/ | tee tests_output.txt
601
                  fi
602
            - store_artifacts:
603
604
605
                  path: ~/transformers/examples_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
606

607
608
609
    run_examples_torch_all:
        working_directory: ~/transformers
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
610
            - image: circleci/python:3.7
611
612
613
614
615
616
617
618
619
620
621
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch_examples-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
622
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev espeak-ng
623
            - run: pip install --upgrade pip
624
            - run: pip install .[sklearn,torch,sentencepiece,testing,torch-speech]
625
            - run: pip install -r examples/pytorch/_tests_requirements.txt
626
            - run: pip install git+https://github.com/huggingface/accelerate
627
628
629
630
631
632
633
634
635
636
            - save_cache:
                  key: v0.4-torch_examples-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  TRANSFORMERS_IS_CI=1 python -m pytest -n 8 --dist=loadfile -s --make-reports=examples_torch ./examples/pytorch/ | tee examples_output.txt
            - store_artifacts:
                  path: ~/transformers/examples_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
637

Suraj Patil's avatar
Suraj Patil committed
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
    run_examples_flax:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                keys:
                    - v0.4-flax_examples-{{ checksum "setup.py" }}
                    - v0.4-{{ checksum "setup.py" }}
            - run: pip install --upgrade pip
            - run: sudo pip install .[flax,testing,sentencepiece]
            - run: pip install -r examples/flax/_tests_requirements.txt
            - save_cache:
                  key: v0.4-flax_examples-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: python utils/tests_fetcher.py --filters examples tests | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
                    python -m pytest -n 8 --dist=loadfile -s --make-reports=examples_flax ./examples/flax/ | tee tests_output.txt
                  fi
            - store_artifacts:
                  path: ~/transformers/flax_examples_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
671

Suraj Patil's avatar
Suraj Patil committed
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
    run_examples_flax_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                keys:
                    - v0.4-flax_examples-{{ checksum "setup.py" }}
                    - v0.4-{{ checksum "setup.py" }}
            - run: pip install --upgrade pip
            - run: sudo pip install .[flax,testing,sentencepiece]
            - run: pip install -r examples/flax/_tests_requirements.txt
            - save_cache:
                  key: v0.4-flax_examples-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  TRANSFORMERS_IS_CI=1 python -m pytest -n 8 --dist=loadfile -s --make-reports=examples_flax ./examples/flax/ | tee examples_output.txt
            - store_artifacts:
                  path: ~/transformers/flax_examples_output.txt
            - store_artifacts:
                  path: ~/transformers/reports

Sylvain Gugger's avatar
Sylvain Gugger committed
701
    run_tests_hub:
702
703
704
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
705
        environment:
Sylvain Gugger's avatar
Sylvain Gugger committed
706
            HUGGINGFACE_CO_STAGING: yes
707
708
            RUN_GIT_LFS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
709
710
711
712
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
Sylvain Gugger's avatar
Sylvain Gugger committed
713
714
715
716
            - restore_cache:
                  keys:
                      - v0.4-hub-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
717
718
719
720
721
            - run: sudo apt-get install git-lfs
            - run: |
                git config --global user.email "ci@dummy.com"
                git config --global user.name "ci"
            - run: pip install --upgrade pip
Sylvain Gugger's avatar
Sylvain Gugger committed
722
723
724
725
726
            - run: pip install .[torch,sentencepiece,testing]
            - save_cache:
                  key: v0.4-hub-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
727
728
729
730
731
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
732
                    python -m pytest -sv --make-reports=tests_hub $(cat test_list.txt) -m is_staging_test | tee tests_output.txt
733
                  fi
734
735
736
737
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
738

739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
    run_tests_hub_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            HUGGINGFACE_CO_STAGING: yes
            RUN_GIT_LFS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-hub-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
            - run: sudo apt-get install git-lfs
            - run: |
                git config --global user.email "ci@dummy.com"
                git config --global user.name "ci"
            - run: pip install --upgrade pip
            - run: pip install .[torch,sentencepiece,testing]
            - save_cache:
                  key: v0.4-hub-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  python -m pytest -sv --make-reports=tests_hub tests -m is_staging_test | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
771

772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
    run_tests_onnxruntime:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
            - run: pip install --upgrade pip
788
            - run: pip install .[torch,testing,sentencepiece,onnxruntime,vision,rjieba]
789
790
791
792
            - save_cache:
                  key: v0.4-onnx-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
793
794
795
796
797
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
798
                    python -m pytest -n 1 --dist=loadfile -s --make-reports=tests_onnx $(cat test_list.txt) -k onnx | tee tests_output.txt
799
                  fi
800
801
802
803
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
804

805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
    run_tests_onnxruntime_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
            - run: pip install --upgrade pip
lewtun's avatar
lewtun committed
821
            - run: pip install .[torch,testing,sentencepiece,onnxruntime,vision]
822
823
824
825
826
827
828
829
830
831
832
            - save_cache:
                  key: v0.4-onnx-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
                  python -m pytest -n 1 --dist=loadfile -s --make-reports=tests_onnx tests -k onnx | tee tests_output.txt
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports

Aymeric Augustin's avatar
Aymeric Augustin committed
833
834
835
    check_code_quality:
        working_directory: ~/transformers
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
836
            - image: circleci/python:3.7
Lysandre's avatar
Lysandre committed
837
        resource_class: large
838
839
        environment:
            TRANSFORMERS_IS_CI: yes
Aymeric Augustin's avatar
Aymeric Augustin committed
840
841
842
        parallelism: 1
        steps:
            - checkout
843
844
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
845
846
                      - v0.4-code_quality-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
847
            - run: pip install --upgrade pip
848
            - run: pip install .[all,quality]
849
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
850
                  key: v0.4-code_quality-{{ checksum "setup.py" }}
851
852
                  paths:
                      - '~/.cache/pip'
853
854
            - run: black --check examples tests src utils
            - run: isort --check-only examples tests src utils
Sylvain Gugger's avatar
Sylvain Gugger committed
855
            - run: python utils/custom_init_isort.py --check_only
856
            - run: flake8 examples tests src utils
857
            - run: doc-builder style src/transformers docs/source --max_len 119 --check_only --path_to_docs docs/source
858

859
    check_repository_consistency:
R茅mi Louf's avatar
R茅mi Louf committed
860
861
        working_directory: ~/transformers
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
862
            - image: circleci/python:3.7
Sylvain Gugger's avatar
Sylvain Gugger committed
863
864
865
        resource_class: large
        environment:
            TRANSFORMERS_IS_CI: yes
R茅mi Louf's avatar
R茅mi Louf committed
866
867
868
        parallelism: 1
        steps:
            - checkout
Sylvain Gugger's avatar
Sylvain Gugger committed
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
            - restore_cache:
                  keys:
                      - v0.4-repository_consistency-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
            - run: pip install --upgrade pip
            - run: pip install .[all,quality]
            - save_cache:
                  key: v0.4-repository_consistency-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: python utils/check_copies.py
            - run: python utils/check_table.py
            - run: python utils/check_dummies.py
            - run: python utils/check_repo.py
            - run: python utils/check_inits.py
884
            - run: python utils/check_config_docstrings.py
Sylvain Gugger's avatar
Sylvain Gugger committed
885
886
            - run: make deps_table_check_updated
            - run: python utils/tests_fetcher.py --sanity_check
887

888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
909
910
911
912
913
914
915
916
917
918
    run_tests_layoutlmv2:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
            TRANSFORMERS_IS_CI: yes
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
            - run: pip install --upgrade pip
            - run: pip install .[torch,testing,vision]
            - run: pip install torchvision
            - run: python -m pip install 'git+https://github.com/facebookresearch/detectron2.git'
            - run: sudo apt install tesseract-ocr
            - run: pip install pytesseract
            - save_cache:
                  key: v0.4-torch-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
Yih-Dar's avatar
Yih-Dar committed
919
                    python -m pytest -n 1 tests/models/*layoutlmv2* --dist=loadfile -s --make-reports=tests_layoutlmv2 --durations=100
920
921
922
923
924
925
                  fi
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports

926
927
928
# TPU JOBS
    run_examples_tpu:
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
929
            - image: circleci/python:3.7
930
931
        environment:
            OMP_NUM_THREADS: 1
932
            TRANSFORMERS_IS_CI: yes
933
934
935
936
937
938
939
940
941
942
943
944
945
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - go/install
            - *checkout_ml_testing
            - gcp-gke/install
            - gcp-gke/update-kubeconfig-with-credentials:
                  cluster: $GKE_CLUSTER
                  perform-login: true
            - setup_remote_docker
            - *build_push_docker
            - *deploy_cluster
946

947
948
    cleanup-gke-jobs:
        docker:
Sylvain Gugger's avatar
Sylvain Gugger committed
949
            - image: circleci/python:3.7
950
951
952
953
954
955
        steps:
            - gcp-gke/install
            - gcp-gke/update-kubeconfig-with-credentials:
                  cluster: $GKE_CLUSTER
                  perform-login: true
            - *delete_gke_jobs
956

LysandreJik's avatar
LysandreJik committed
957
958
959
960
workflow_filters: &workflow_filters
    filters:
        branches:
            only:
961
                - main
962
workflows:
LysandreJik's avatar
LysandreJik committed
963
964
965
    version: 2
    build_and_test:
        jobs:
Aymeric Augustin's avatar
Aymeric Augustin committed
966
            - check_code_quality
967
            - check_repository_consistency
Aymeric Augustin's avatar
Aymeric Augustin committed
968
            - run_examples_torch
969
            - run_examples_flax
Aymeric Augustin's avatar
Aymeric Augustin committed
970
971
            - run_tests_custom_tokenizers
            - run_tests_torch_and_tf
972
            - run_tests_torch_and_flax
Aymeric Augustin's avatar
Aymeric Augustin committed
973
974
            - run_tests_torch
            - run_tests_tf
975
            - run_tests_flax
976
977
            - run_tests_pipelines_torch
            - run_tests_pipelines_tf
978
            - run_tests_onnxruntime
Sylvain Gugger's avatar
Sylvain Gugger committed
979
            - run_tests_hub
980
            - run_tests_layoutlmv2
981
982
983
984
985
986
987
    nightly:
        triggers:
            - schedule:
                cron: "0 0 * * *"
                filters:
                    branches:
                        only:
988
                            - main
989
        jobs:
990
            - run_examples_torch_all
991
            - run_examples_flax_all
992
993
994
995
996
997
998
999
1000
1001
            - run_tests_torch_and_tf_all
            - run_tests_torch_and_flax_all
            - run_tests_torch_all
            - run_tests_tf_all
            - run_tests_flax_all
            - run_tests_pipelines_torch_all
            - run_tests_pipelines_tf_all
            - run_tests_onnxruntime_all
            - run_tests_hub_all

1002
1003
1004
1005
1006
1007
1008
1009
#    tpu_testing_jobs:
#        triggers:
#            - schedule:
#                # Set to run at the first minute of every hour.
#                cron: "0 8 * * *"
#                filters:
#                    branches:
#                        only:
1010
#                            - main
1011
1012
1013
#        jobs:
#            - cleanup-gke-jobs
#            - run_examples_tpu