config.yml 41 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" }}
Suraj Patil's avatar
Suraj Patil committed
81
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
82
            - run: pip install --upgrade pip
83
            - run: pip install .[sklearn,tf-cpu,torch,testing,sentencepiece,torch-speech,vision]
Lysandre Debut's avatar
Lysandre Debut committed
84
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.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
119
120
        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" }}
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
            - run: pip install --upgrade pip
121
            - run: pip install .[sklearn,tf-cpu,torch,testing,sentencepiece,torch-speech,vision]
Lysandre Debut's avatar
Lysandre Debut committed
122
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.0+cpu.html
Kamal Raj's avatar
Kamal Raj committed
123
            - run: pip install tensorflow_probability
124
125
126
127
128
129
130
131
132
133
            - 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
134

135
136
137
138
139
140
    run_tests_torch_and_flax:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.6
        environment:
            OMP_NUM_THREADS: 1
141
142
            RUN_PT_FLAX_CROSS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
143
144
145
146
147
148
149
150
151
152
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
                      - v0.4-torch_and_flax-{{ 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
153
            - run: pip install .[sklearn,flax,torch,testing,sentencepiece,torch-speech,vision]
Lysandre Debut's avatar
Lysandre Debut committed
154
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.0+cpu.html
155
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
156
157
158
159
            - save_cache:
                key: v0.4-{{ checksum "setup.py" }}
                paths:
                    - '~/.cache/pip'
160
161
162
163
164
165
166
            - 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
167
168
169
170
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
    
    run_tests_torch_and_flax_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.6
        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" }}
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
            - run: pip install --upgrade pip
190
            - run: pip install .[sklearn,flax,torch,testing,sentencepiece,torch-speech,vision]
Lysandre Debut's avatar
Lysandre Debut committed
191
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.0+cpu.html
192
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
193
194
195
196
197
198
199
200
201
202
            - 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
203

Aymeric Augustin's avatar
Aymeric Augustin committed
204
    run_tests_torch:
205
        working_directory: ~/transformers
Julien Chaumond's avatar
Julien Chaumond committed
206
        docker:
207
            - image: circleci/python:3.7
208
209
        environment:
            OMP_NUM_THREADS: 1
210
            TRANSFORMERS_IS_CI: yes
211
        resource_class: xlarge
212
        parallelism: 1
Julien Chaumond's avatar
Julien Chaumond committed
213
214
        steps:
            - checkout
215
216
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
217
218
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
Suraj Patil's avatar
Suraj Patil committed
219
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
220
            - run: pip install --upgrade pip
221
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
Lysandre Debut's avatar
Lysandre Debut committed
222
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.0+cpu.html
223
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
224
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
225
                  key: v0.4-torch-{{ checksum "setup.py" }}
226
227
                  paths:
                      - '~/.cache/pip'
228
229
230
231
232
233
234
            - 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
235
            - store_artifacts:
236
237
238
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
    
    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" }}
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
            - run: pip install --upgrade pip
257
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
Lysandre Debut's avatar
Lysandre Debut committed
258
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.0+cpu.html
259
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
260
261
262
263
264
265
266
267
268
269
            - 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
270

Aymeric Augustin's avatar
Aymeric Augustin committed
271
    run_tests_tf:
272
        working_directory: ~/transformers
thomwolf's avatar
thomwolf committed
273
        docker:
274
            - image: circleci/python:3.7
275
276
        environment:
            OMP_NUM_THREADS: 1
277
            TRANSFORMERS_IS_CI: yes
thomwolf's avatar
thomwolf committed
278
279
280
281
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
282
283
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
284
285
                      - v0.4-tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
286
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
287
            - run: pip install --upgrade pip
288
            - run: pip install .[sklearn,tf-cpu,testing,sentencepiece,tf-speech,vision]
Kamal Raj's avatar
Kamal Raj committed
289
            - run: pip install tensorflow_probability
290
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
291
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
292
                  key: v0.4-tf-{{ checksum "setup.py" }}
293
294
                  paths:
                      - '~/.cache/pip'
295
296
297
298
299
300
301
            - 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
302
            - store_artifacts:
303
304
305
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
    
    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" }}
322
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
323
            - run: pip install --upgrade pip
324
            - run: pip install .[sklearn,tf-cpu,testing,sentencepiece,tf-speech,vision]
Kamal Raj's avatar
Kamal Raj committed
325
            - run: pip install tensorflow_probability
326
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
327
328
329
330
331
332
333
334
335
336
            - 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
337

338
339
340
341
342
343
    run_tests_flax:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
344
            TRANSFORMERS_IS_CI: yes
345
346
347
348
349
350
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                keys:
Lysandre Debut's avatar
Lysandre Debut committed
351
352
                    - v0.4-flax-{{ checksum "setup.py" }}
                    - v0.4-{{ checksum "setup.py" }}
353
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
354
            - run: pip install --upgrade pip
355
356
            - run: pip install .[flax,testing,sentencepiece,flax-speech,vision]
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
357
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
358
                  key: v0.4-flax-{{ checksum "setup.py" }}
359
360
                  paths:
                      - '~/.cache/pip'
361
362
363
364
365
366
367
            - 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
368
            - store_artifacts:
369
370
371
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
    
    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" }}
388
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
389
            - run: pip install --upgrade pip
390
391
            - run: pip install .[flax,testing,sentencepiece,vision,flax-speech]
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
392
393
394
395
396
397
398
399
400
401
            - 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
402

403
404
405
406
407
408
    run_tests_pipelines_torch:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
409
410
            RUN_PIPELINE_TESTS: yes
            TRANSFORMERS_IS_CI: yes
411
412
413
414
415
416
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
417
418
                      - v0.4-torch-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
Suraj Patil's avatar
Suraj Patil committed
419
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
420
            - run: pip install --upgrade pip
421
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
Lysandre Debut's avatar
Lysandre Debut committed
422
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.0+cpu.html
423
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
424
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
425
                  key: v0.4-torch-{{ checksum "setup.py" }}
426
427
                  paths:
                      - '~/.cache/pip'
428
429
430
431
432
433
434
            - 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
435
            - store_artifacts:
436
437
438
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
    
    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" }}
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
            - run: pip install --upgrade pip
458
            - run: pip install .[sklearn,torch,testing,sentencepiece,torch-speech,vision,timm]
Lysandre Debut's avatar
Lysandre Debut committed
459
            - run: pip install torch-scatter -f https://pytorch-geometric.com/whl/torch-1.10.0+cpu.html
460
            - run: pip install https://github.com/kpu/kenlm/archive/master.zip
461
462
463
464
465
466
467
468
469
470
            - 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
471

472
473
474
475
476
477
    run_tests_pipelines_tf:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
        environment:
            OMP_NUM_THREADS: 1
478
479
            RUN_PIPELINE_TESTS: yes
            TRANSFORMERS_IS_CI: yes
480
481
482
483
484
485
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
486
487
                      - v0.4-tf-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
488
            - run: pip install --upgrade pip
489
            - run: pip install .[sklearn,tf-cpu,testing,sentencepiece]
Kamal Raj's avatar
Kamal Raj committed
490
            - run: pip install tensorflow_probability
491
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
492
                  key: v0.4-tf-{{ checksum "setup.py" }}
493
494
                  paths:
                      - '~/.cache/pip'
495
496
497
498
499
500
501
            - 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
502
503
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
504
            - store_artifacts:
505
506
                  path: ~/transformers/reports

507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
    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
525
            - run: pip install tensorflow_probability
526
527
528
529
530
            - save_cache:
                  key: v0.4-tf-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
            - run: |
531
                  python -m pytest -n 8 --dist=loadfile -rA -s --make-reports=tests_pipelines_tf tests -m is_pipeline_test | tee tests_output.txt
532
533
534
535
536
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports

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

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

601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
    run_examples_torch_all:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.6
        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" }}
616
            - run: sudo apt-get -y update && sudo apt-get install -y libsndfile1-dev
617
            - run: pip install --upgrade pip
618
            - run: pip install .[sklearn,torch,sentencepiece,testing,torch-speech]
619
620
621
622
623
624
625
626
627
628
629
            - run: pip install -r examples/pytorch/_tests_requirements.txt
            - 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
630

Suraj Patil's avatar
Suraj Patil committed
631
632
633
634
635
636
637
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
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
    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
    
    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
694
    run_tests_hub:
695
696
697
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.7
698
        environment:
Sylvain Gugger's avatar
Sylvain Gugger committed
699
            HUGGINGFACE_CO_STAGING: yes
700
701
            RUN_GIT_LFS_TESTS: yes
            TRANSFORMERS_IS_CI: yes
702
703
704
705
        resource_class: xlarge
        parallelism: 1
        steps:
            - checkout
Sylvain Gugger's avatar
Sylvain Gugger committed
706
707
708
709
            - restore_cache:
                  keys:
                      - v0.4-hub-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
710
711
712
713
714
            - 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
715
716
717
718
719
            - run: pip install .[torch,sentencepiece,testing]
            - save_cache:
                  key: v0.4-hub-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
720
721
722
723
724
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
725
                    python -m pytest -sv --make-reports=tests_hub $(cat test_list.txt) -m is_staging_test | tee tests_output.txt
726
                  fi
727
728
729
730
731
732
733
734
735
736
737
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
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
    
    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
764

765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
    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
            - run: pip install .[torch,testing,sentencepiece,onnxruntime]
            - save_cache:
                  key: v0.4-onnx-{{ checksum "setup.py" }}
                  paths:
                      - '~/.cache/pip'
786
787
788
789
790
            - run: python utils/tests_fetcher.py | tee test_preparation.txt
            - store_artifacts:
                  path: ~/transformers/test_preparation.txt
            - run: |
                  if [ -f test_list.txt ]; then
791
                    python -m pytest -n 1 --dist=loadfile -s --make-reports=tests_onnx $(cat test_list.txt) -k onnx | tee tests_output.txt
792
                  fi
793
794
795
796
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
    
    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
            - run: pip install .[torch,testing,sentencepiece,onnxruntime]
            - 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
826
827
828
829
    check_code_quality:
        working_directory: ~/transformers
        docker:
            - image: circleci/python:3.6
Lysandre's avatar
Lysandre committed
830
        resource_class: large
831
832
        environment:
            TRANSFORMERS_IS_CI: yes
Aymeric Augustin's avatar
Aymeric Augustin committed
833
834
835
        parallelism: 1
        steps:
            - checkout
836
837
            - restore_cache:
                  keys:
Lysandre Debut's avatar
Lysandre Debut committed
838
839
                      - v0.4-code_quality-{{ checksum "setup.py" }}
                      - v0.4-{{ checksum "setup.py" }}
840
            - run: pip install --upgrade pip
841
            - run: pip install .[all,quality]
842
            - save_cache:
Lysandre Debut's avatar
Lysandre Debut committed
843
                  key: v0.4-code_quality-{{ checksum "setup.py" }}
844
845
                  paths:
                      - '~/.cache/pip'
846
847
            - run: black --check examples tests src utils
            - run: isort --check-only examples tests src utils
Sylvain Gugger's avatar
Sylvain Gugger committed
848
            - run: python utils/custom_init_isort.py --check_only
849
            - run: flake8 examples tests src utils
Sylvain Gugger's avatar
Sylvain Gugger committed
850
            - run: python utils/style_doc.py src/transformers docs/source --max_len 119 --check_only
851

852
    check_repository_consistency:
R茅mi Louf's avatar
R茅mi Louf committed
853
854
        working_directory: ~/transformers
        docker:
855
            - image: circleci/python:3.6
Sylvain Gugger's avatar
Sylvain Gugger committed
856
857
858
        resource_class: large
        environment:
            TRANSFORMERS_IS_CI: yes
R茅mi Louf's avatar
R茅mi Louf committed
859
860
861
        parallelism: 1
        steps:
            - checkout
Sylvain Gugger's avatar
Sylvain Gugger committed
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
            - 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
            - run: make deps_table_check_updated
            - run: python utils/tests_fetcher.py --sanity_check
879

880
881
882
883
884
885
886
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
    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
                    python -m pytest -n 1 tests/*layoutlmv2* --dist=loadfile -s --make-reports=tests_layoutlmv2 --durations=100
                  fi
            - store_artifacts:
                  path: ~/transformers/tests_output.txt
            - store_artifacts:
                  path: ~/transformers/reports

918
919
920
921
922
923
# TPU JOBS
    run_examples_tpu:
        docker:
            - image: circleci/python:3.6
        environment:
            OMP_NUM_THREADS: 1
924
            TRANSFORMERS_IS_CI: yes
925
926
927
928
929
930
931
932
933
934
935
936
937
        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
938

939
940
941
942
943
944
945
946
947
    cleanup-gke-jobs:
        docker:
            - image: circleci/python:3.6
        steps:
            - gcp-gke/install
            - gcp-gke/update-kubeconfig-with-credentials:
                  cluster: $GKE_CLUSTER
                  perform-login: true
            - *delete_gke_jobs
948

LysandreJik's avatar
LysandreJik committed
949
950
951
952
workflow_filters: &workflow_filters
    filters:
        branches:
            only:
Lysandre's avatar
Lysandre committed
953
                - master
954
workflows:
LysandreJik's avatar
LysandreJik committed
955
956
957
    version: 2
    build_and_test:
        jobs:
Aymeric Augustin's avatar
Aymeric Augustin committed
958
            - check_code_quality
959
            - check_repository_consistency
Aymeric Augustin's avatar
Aymeric Augustin committed
960
            - run_examples_torch
961
            - run_examples_flax
Aymeric Augustin's avatar
Aymeric Augustin committed
962
963
            - run_tests_custom_tokenizers
            - run_tests_torch_and_tf
964
            - run_tests_torch_and_flax
Aymeric Augustin's avatar
Aymeric Augustin committed
965
966
            - run_tests_torch
            - run_tests_tf
967
            - run_tests_flax
968
969
            - run_tests_pipelines_torch
            - run_tests_pipelines_tf
970
            - run_tests_onnxruntime
Sylvain Gugger's avatar
Sylvain Gugger committed
971
            - run_tests_hub
972
            - run_tests_layoutlmv2
973
974
975
976
977
978
979
980
981
    nightly:
        triggers:
            - schedule:
                cron: "0 0 * * *"
                filters:
                    branches:
                        only:
                            - master
        jobs:
982
            - run_examples_torch_all
983
            - run_examples_flax_all
984
985
986
987
988
989
990
991
992
993
            - 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

994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
#    tpu_testing_jobs:
#        triggers:
#            - schedule:
#                # Set to run at the first minute of every hour.
#                cron: "0 8 * * *"
#                filters:
#                    branches:
#                        only:
#                            - master
#        jobs:
#            - cleanup-gke-jobs
#            - run_examples_tpu