config.yml.in 30.2 KB
Newer Older
1
2
3
4
version: 2.1

# How to test the Linux jobs:
#   - Install CircleCI local CLI: https://circleci.com/docs/2.0/local-cli/
5
6
#   - circleci config process .circleci/config.yml > gen.yml && circleci local execute -c gen.yml --job binary_linux_wheel_py3.8
#     - Replace binary_linux_wheel_py3.8 with the name of the job you want to test.
Edward Z. Yang's avatar
Edward Z. Yang committed
7
#       Job names are 'name:' key.
8

9
10
11
12
13
14
executors:
  windows-cpu:
    machine:
      resource_class: windows.xlarge
      image: windows-server-2019-vs2019:stable
      shell: bash.exe
peterjc123's avatar
peterjc123 committed
15

16
17
18
  windows-gpu:
    machine:
      resource_class: windows.gpu.nvidia.medium
19
      image: windows-server-2019-nvidia:stable
20
21
      shell: bash.exe

22
commands:
23
24
25
26
27
28
  generate_cache_key:
    description: "Generates a cache key file that changes daily"
    steps:
      - run:
          name: Generate cache key
          command: echo "$(date +"%Y-%m-%d")" > .cachekey
29
30
31
32
33
34
35
36
  designate_upload_channel:
    description: "inserts the correct upload channel into ${BASH_ENV}"
    steps:
      - run:
          name: adding UPLOAD_CHANNEL to BASH_ENV
          command: |
            our_upload_channel=nightly
            # On tags upload to test instead
37
            if [[ -n "${CIRCLE_TAG}" ]] || [[ ${CIRCLE_BRANCH} =~ release/* ]]; then
38
39
40
              our_upload_channel=test
            fi
            echo "export UPLOAD_CHANNEL=${our_upload_channel}" >> ${BASH_ENV}
Eli Uriegas's avatar
Eli Uriegas committed
41
42
43
44
45
46
47
  load_conda_channel_flags:
    description: "Determines whether we need extra conda channels"
    steps:
      - run:
          name: Adding CONDA_CHANNEL_FLAGS to BASH_ENV
          command: |
              CONDA_CHANNEL_FLAGS=""
48
              # formerly used to add conda-forge flags for Python 3.9, reserving the mechanism for future python upgrades
49
50
51
52
53
54
55
  windows_install_cuda:
    description: "Install desired CUDA version on Windows runners"
    steps:
      - run:
          name: Install CUDA
          command: |
              packaging/windows/internal/cuda_install.bat
56

57
58
binary_common: &binary_common
  parameters:
Edward Z. Yang's avatar
Edward Z. Yang committed
59
    # Edit these defaults to do a release
60
61
62
63
64
65
66
67
68
69
    build_version:
      description: "version number of release binary; by default, build a nightly"
      type: string
      default: ""
    pytorch_version:
      description: "PyTorch version to build against; by default, use a nightly"
      type: string
      default: ""
    # Don't edit these
    python_version:
70
      description: "Python version to build against (e.g., 3.8)"
71
      type: string
Nikita Shulga's avatar
Nikita Shulga committed
72
73
74
75
76
77
78
79
80
81
82
83
    cuda_version:
      description: "CUDA version to build against (e.g., cpu, cu101)"
      type: string
      default: "cpu"
    wheel_docker_image:
      description: "Wheel only: what docker image to use"
      type: string
      default: "pytorch/manylinux-cuda102"
    conda_docker_image:
      description: "Conda only: what docker image to use"
      type: string
      default: "pytorch/conda-builder:cuda102"
84
  environment: &environment
85
86
87
    PYTHON_VERSION: << parameters.python_version >>
    BUILD_VERSION: << parameters.build_version >>
    PYTORCH_VERSION: << parameters.pytorch_version >>
Nikita Shulga's avatar
Nikita Shulga committed
88
    CU_VERSION: << parameters.cuda_version >>
89
    MACOSX_DEPLOYMENT_TARGET: 10.9
90

Mingbo Wan's avatar
Mingbo Wan committed
91
92
93
smoke_test_common: &smoke_test_common
  <<: *binary_common
  docker:
94
    - image: pytorch/torchaudio_unittest_base:smoke_test-20220425
Caroline Chen's avatar
Caroline Chen committed
95
  resource_class: large
Mingbo Wan's avatar
Mingbo Wan committed
96

97
98
99
jobs:
  circleci_consistency:
    docker:
moto's avatar
moto committed
100
      - image: cimg/python:3.8
101
102
103
104
    steps:
      - checkout
      - run:
          command: |
105
            pip install --user --progress-bar off jinja2 pyyaml
106
107
108
            python .circleci/regenerate.py
            git diff --exit-code || (echo ".circleci/config.yml not in sync with config.yml.in! Run .circleci/regenerate.py to update config"; exit 1)

109
110
111
112
113
114
115
116
117
118
119
120
121
  lint_python_and_config:
    docker:
      - image: circleci/python:3.7
    steps:
      - checkout
      - run:
          name: Install pre-commit
          command: pip install --user --progress-bar off pre-commit
      - run:
          name: Install pre-commit hooks
          command: pre-commit install-hooks
      - run:
          name: Lint Python code and config files
moto's avatar
moto committed
122
          command: pre-commit run --all-files
123
124
      - run:
          name: Required lint modifications
125
          when: always
moto's avatar
moto committed
126
          command: git --no-pager diff --color=always
127

128
  download_third_parties:
129
    docker:
moto's avatar
moto committed
130
      - image: "pytorch/torchaudio_unittest_base:manylinux"
131
132
133
    resource_class: small
    steps:
      - checkout
134
      - generate_cache_key
135
136
137
      - restore_cache:
          {% raw %}
          keys:
moto's avatar
moto committed
138
            - tp-nix-v2-{{ checksum ".cachekey" }}
139
140
          {% endraw %}
      - run:
moto's avatar
moto committed
141
          command: |
142
143
              mkdir -p third_party/archives/
              wget --no-clobber --directory-prefix=third_party/archives/ $(awk '/URL /{print $2}' third_party/*/CMakeLists.txt)
144
145
      - save_cache:
          {% raw %}
moto's avatar
moto committed
146
          key: tp-nix-v2-{{ checksum ".cachekey" }}
147
148
          {% endraw %}
          paths:
149
            - third_party/archives
150
151
152
      - persist_to_workspace:
          root: third_party
          paths:
153
            - archives
154

155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
  build_ffmpeg_linux:
    <<: *binary_common
    docker:
      - image: << parameters.wheel_docker_image >>
    resource_class: 2xlarge+
    steps:
      - checkout
      - generate_cache_key
      - restore_cache:
          {% raw %}
          keys:
            - ffmpeg-linux-v0-{{ checksum ".cachekey" }}
          {% endraw %}
      - run:
          command: |
            export FFMPEG_ROOT=${PWD}/third_party/ffmpeg
            if [[ ! -d ${FFMPEG_ROOT} ]]; then
                packaging/ffmpeg/build.sh
            fi
      - save_cache:
          {% raw %}
          key: ffmpeg-linux-v0-{{ checksum ".cachekey" }}
          {% endraw %}
          paths:
            - third_party/ffmpeg
      - persist_to_workspace:
          root: third_party
          paths:
            - ffmpeg

  build_ffmpeg_macos:
    <<: *binary_common
    macos:
188
      xcode: "14.0"
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
    steps:
      - checkout
      - generate_cache_key
      - restore_cache:
          {% raw %}
          keys:
            - ffmpeg-macos-v0-{{ checksum ".cachekey" }}
          {% endraw %}
      - run:
          command: |
            export FFMPEG_ROOT=${PWD}/third_party/ffmpeg
            if [[ ! -d ${FFMPEG_ROOT} ]]; then
                packaging/ffmpeg/build.sh
            fi
      - save_cache:
          {% raw %}
          key: ffmpeg-macos-v0-{{ checksum ".cachekey" }}
          {% endraw %}
          paths:
            - third_party/ffmpeg
      - persist_to_workspace:
          root: third_party
          paths:
            - ffmpeg

  build_ffmpeg_windows:
    <<: *binary_common
    machine:
      resource_class: windows.xlarge
      image: windows-server-2019-vs2019:stable
      # Note:
      # Unlike other Windows job, this job uses cmd.exe as shell because
      # we need to invoke bash.exe from msys2 in ffmpeg build process, and doing so
      # from different installation of bash.exe (the one from the VM) cause issue
      shell: cmd.exe
    steps:
      - checkout
      - run: date /t > .cachekey
      - restore_cache:
          {% raw %}
          keys:
            - ffmpeg-windows-{{ checksum ".cachekey" }}
          {% endraw %}
      - run: packaging\ffmpeg\build.bat
      - save_cache:
          {% raw %}
          key: ffmpeg-windows-{{ checksum ".cachekey" }}
          {% endraw %}
          paths:
            - third_party/ffmpeg
      - persist_to_workspace:
          root: third_party
          paths:
            - ffmpeg

244
245
246
  binary_linux_wheel:
    <<: *binary_common
    docker:
Nikita Shulga's avatar
Nikita Shulga committed
247
      - image: << parameters.wheel_docker_image >>
248
249
250
    resource_class: 2xlarge+
    steps:
      - checkout
251
252
      - attach_workspace:
          at: third_party
253
254
      - run:
          command: |
255
            export FFMPEG_ROOT=${PWD}/third_party/ffmpeg
256
            packaging/build_wheel.sh
257
          environment:
258
            USE_FFMPEG: true
259
260
      - store_artifacts:
          path: dist
Edward Z. Yang's avatar
Edward Z. Yang committed
261
262
263
264
      - persist_to_workspace:
          root: dist
          paths:
            - "*"
265
266
267
268

  binary_linux_conda:
    <<: *binary_common
    docker:
Nikita Shulga's avatar
Nikita Shulga committed
269
      - image: "<< parameters.conda_docker_image >>"
270
271
272
    resource_class: 2xlarge+
    steps:
      - checkout
Eli Uriegas's avatar
Eli Uriegas committed
273
      - load_conda_channel_flags
274
275
      - attach_workspace:
          at: third_party
276
      - run:
277
278
279
          command: |
            export FFMPEG_ROOT=${PWD}/third_party/ffmpeg
            packaging/build_conda.sh
280
          environment:
281
            USE_FFMPEG: true
282
283
      - store_artifacts:
          path: /opt/conda/conda-bld/linux-64
Edward Z. Yang's avatar
Edward Z. Yang committed
284
      - persist_to_workspace:
285
          root: /opt/conda
Edward Z. Yang's avatar
Edward Z. Yang committed
286
          paths:
287
            - "conda-bld/*"
288
289
290
291

  binary_macos_wheel:
    <<: *binary_common
    macos:
292
      xcode: "14.0"
293
294
    steps:
      - checkout
Eli Uriegas's avatar
Eli Uriegas committed
295
      - load_conda_channel_flags
296
297
      - attach_workspace:
          at: third_party
298
299
300
301
302
303
304
305
      - run:
          # Cannot easily deduplicate this as source'ing activate
          # will set environment variables which we need to propagate
          # to build_wheel.sh
          command: |
            curl -o conda.sh https://repo.anaconda.com/miniconda/Miniconda3-latest-MacOSX-x86_64.sh
            sh conda.sh -b
            source $HOME/miniconda3/bin/activate
306
            export FFMPEG_ROOT="${PWD}/third_party/ffmpeg"
307
            packaging/build_wheel.sh
308
          environment:
309
            USE_FFMPEG: true
moto's avatar
moto committed
310
            USE_OPENMP: false
311
312
      - store_artifacts:
          path: dist
Edward Z. Yang's avatar
Edward Z. Yang committed
313
314
315
316
      - persist_to_workspace:
          root: dist
          paths:
            - "*"
317
318
319
320

  binary_macos_conda:
    <<: *binary_common
    macos:
321
      xcode: "14.0"
322
323
    steps:
      - checkout
Eli Uriegas's avatar
Eli Uriegas committed
324
      - load_conda_channel_flags
325
326
      - attach_workspace:
          at: third_party
327
328
329
330
331
332
      - run:
          command: |
            curl -o conda.sh https://repo.anaconda.com/miniconda/Miniconda3-latest-MacOSX-x86_64.sh
            sh conda.sh -b
            source $HOME/miniconda3/bin/activate
            conda install -yq conda-build
333
            export FFMPEG_ROOT="${PWD}/third_party/ffmpeg"
334
            packaging/build_conda.sh
335
          environment:
336
            USE_FFMPEG: true
moto's avatar
moto committed
337
            USE_OPENMP: false
338
339
      - store_artifacts:
          path: /Users/distiller/miniconda3/conda-bld/osx-64
Edward Z. Yang's avatar
Edward Z. Yang committed
340
      - persist_to_workspace:
341
          root: /Users/distiller/miniconda3
Edward Z. Yang's avatar
Edward Z. Yang committed
342
          paths:
343
            - "conda-bld/*"
344

peterjc123's avatar
peterjc123 committed
345
346
347
348
349
350
  binary_windows_wheel:
    <<: *binary_common
    executor:
      name: windows-cpu
    steps:
      - checkout
Eli Uriegas's avatar
Eli Uriegas committed
351
      - load_conda_channel_flags
352
      - windows_install_cuda
353
354
      - attach_workspace:
          at: third_party
peterjc123's avatar
peterjc123 committed
355
      - run:
356
          name: Build wheel packages
peterjc123's avatar
peterjc123 committed
357
          command: |
358
            set -ex
peterjc123's avatar
peterjc123 committed
359
360
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda activate base
361
            export FFMPEG_ROOT="${PWD}/third_party/ffmpeg"
peterjc123's avatar
peterjc123 committed
362
            bash packaging/build_wheel.sh
363
          environment:
364
            USE_FFMPEG: true
peterjc123's avatar
peterjc123 committed
365
366
367
368
369
370
371
372
373
374
375
376
377
      - store_artifacts:
          path: dist
      - persist_to_workspace:
          root: dist
          paths:
            - "*"

  binary_windows_conda:
    <<: *binary_common
    executor:
      name: windows-cpu
    steps:
      - checkout
Eli Uriegas's avatar
Eli Uriegas committed
378
      - load_conda_channel_flags
379
      - windows_install_cuda
380
381
      - attach_workspace:
          at: third_party
peterjc123's avatar
peterjc123 committed
382
      - run:
383
          name: Build conda packages
384
          no_output_timeout: 20m
peterjc123's avatar
peterjc123 committed
385
          command: |
386
            set -ex
peterjc123's avatar
peterjc123 committed
387
388
389
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda activate base
            conda install -yq conda-build "conda-package-handling!=1.5.0"
390
            export FFMPEG_ROOT="${PWD}/third_party/ffmpeg"
peterjc123's avatar
peterjc123 committed
391
            bash packaging/build_conda.sh
392
          environment:
393
            USE_FFMPEG: true
peterjc123's avatar
peterjc123 committed
394
395
396
      - store_artifacts:
          path: C:/tools/miniconda3/conda-bld/win-64
      - persist_to_workspace:
397
          root: C:/tools/miniconda3
peterjc123's avatar
peterjc123 committed
398
          paths:
399
            - "conda-bld/*"
peterjc123's avatar
peterjc123 committed
400

Edward Z. Yang's avatar
Edward Z. Yang committed
401
402
403
404
405
406
407
  # Requires org-member context
  binary_conda_upload:
    docker:
      - image: continuumio/miniconda
    steps:
      - attach_workspace:
          at: ~/workspace
408
      - designate_upload_channel
Edward Z. Yang's avatar
Edward Z. Yang committed
409
410
411
412
413
      - run:
          command: |
            # Prevent credential from leaking
            conda install -yq anaconda-client
            set -x
414
            anaconda -t "${CONDA_PYTORCHBOT_TOKEN}" upload ~/workspace/conda-bld/*/*.tar.bz2 -u "pytorch-${UPLOAD_CHANNEL}" --label main --no-progress --force
Edward Z. Yang's avatar
Edward Z. Yang committed
415
416
417

  # Requires org-member context
  binary_wheel_upload:
418
419
420
421
    parameters:
      subfolder:
        description: "What whl subfolder to upload to, e.g., blank or cu100/ (trailing slash is important)"
        type: string
Edward Z. Yang's avatar
Edward Z. Yang committed
422
    docker:
moto's avatar
moto committed
423
      - image: cimg/python:3.8
Edward Z. Yang's avatar
Edward Z. Yang committed
424
425
426
427
    steps:
      - attach_workspace:
          at: ~/workspace
      - checkout
428
      - designate_upload_channel
Edward Z. Yang's avatar
Edward Z. Yang committed
429
430
431
432
433
434
435
436
437
438
      - run:
          command: |
            pip install --user awscli
            export PATH="$HOME/.local/bin:$PATH"
            # Prevent credential from leaking
            set +x
            export AWS_ACCESS_KEY_ID="${PYTORCH_BINARY_AWS_ACCESS_KEY_ID}"
            export AWS_SECRET_ACCESS_KEY="${PYTORCH_BINARY_AWS_SECRET_ACCESS_KEY}"
            set -x
            for pkg in ~/workspace/*.whl; do
439
              aws s3 cp "$pkg" "s3://pytorch/whl/${UPLOAD_CHANNEL}/<< parameters.subfolder >>" --acl public-read
Edward Z. Yang's avatar
Edward Z. Yang committed
440
441
            done

Mingbo Wan's avatar
Mingbo Wan committed
442
443
444
  smoke_test_linux_conda:
    <<: *smoke_test_common
    steps:
Mingbo Wan's avatar
Mingbo Wan committed
445
446
      - attach_workspace:
          at: ~/workspace
447
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
448
      - load_conda_channel_flags
Mingbo Wan's avatar
Mingbo Wan committed
449
      - run:
Mingbo Wan's avatar
Mingbo Wan committed
450
          name: install binaries
Mingbo Wan's avatar
Mingbo Wan committed
451
452
453
          command: |
            set -x
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
454
            conda install -v -y -c pytorch-${UPLOAD_CHANNEL} pytorch cpuonly
455
            conda install -v -y -c file://$HOME/workspace/conda-bld torchaudio
moto's avatar
moto committed
456
      - checkout
Mingbo Wan's avatar
Mingbo Wan committed
457
458
459
460
      - run:
          name: smoke test
          command: |
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
461
            conda install 'ffmpeg<5'
moto's avatar
moto committed
462
            ./test/smoke_test/run_smoke_test.sh
Mingbo Wan's avatar
Mingbo Wan committed
463

Caroline Chen's avatar
Caroline Chen committed
464
465
466
467
468
469
470
471
472
473
474
475
  smoke_test_linux_conda_gpu:
    <<: *smoke_test_common
    steps:
      - attach_workspace:
          at: ~/workspace
      - designate_upload_channel
      - load_conda_channel_flags
      - run:
          name: install binaries
          command: |
            set -x
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
pbialecki's avatar
pbialecki committed
476
            if [[ "$CU_VERSION" == cu116 || "$CU_VERSION" == cu117 ]]; then
477
              conda install -v -y -c pytorch-${UPLOAD_CHANNEL} -c nvidia pytorch pytorch-cuda=${CU_VERSION:2:2}.${CU_VERSION:4}
478
            else
479
              conda install -v -y -c pytorch-${UPLOAD_CHANNEL} pytorch cudatoolkit=${CU_VERSION:2:2}.${CU_VERSION:4}
480
            fi
Caroline Chen's avatar
Caroline Chen committed
481
            conda install -v -y -c file://$HOME/workspace/conda-bld torchaudio
moto's avatar
moto committed
482
      - checkout
Caroline Chen's avatar
Caroline Chen committed
483
484
485
486
      - run:
          name: smoke test
          command: |
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
487
            conda install 'ffmpeg<5'
moto's avatar
moto committed
488
            ./test/smoke_test/run_smoke_test.sh
Caroline Chen's avatar
Caroline Chen committed
489

Mingbo Wan's avatar
Mingbo Wan committed
490
491
492
  smoke_test_linux_pip:
    <<: *smoke_test_common
    steps:
Mingbo Wan's avatar
Mingbo Wan committed
493
494
      - attach_workspace:
          at: ~/workspace
495
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
496
      - load_conda_channel_flags
Mingbo Wan's avatar
Mingbo Wan committed
497
      - run:
Mingbo Wan's avatar
Mingbo Wan committed
498
          name: install binaries
Mingbo Wan's avatar
Mingbo Wan committed
499
500
501
          command: |
            set -x
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
Caroline Chen's avatar
Caroline Chen committed
502
            pip install $(ls ~/workspace/torchaudio*.whl) -f "https://download.pytorch.org/whl/${UPLOAD_CHANNEL}/${CU_VERSION}/torch_${UPLOAD_CHANNEL}.html"
moto's avatar
moto committed
503
      - checkout
Mingbo Wan's avatar
Mingbo Wan committed
504
505
506
507
      - run:
          name: smoke test
          command: |
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
508
            export LD_LIBRARY_PATH="${LD_LIBRARY_PATH}:${HOME}/workspace/ffmpeg/lib"
moto's avatar
moto committed
509
            ./test/smoke_test/run_smoke_test.sh
Mingbo Wan's avatar
Mingbo Wan committed
510

511
512
513
514
515
516
517
  smoke_test_windows_conda:
    <<: *binary_common
    executor:
      name: windows-cpu
    steps:
      - attach_workspace:
          at: ~/workspace
518
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
519
      - load_conda_channel_flags
520
521
522
523
524
525
526
527
      - run:
          name: install binaries
          command: |
            set -x
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda env remove -n python${PYTHON_VERSION} || true
            conda create -yn python${PYTHON_VERSION} python=${PYTHON_VERSION}
            conda activate python${PYTHON_VERSION}
528
            conda install -v -y -c pytorch-${UPLOAD_CHANNEL} pytorch cpuonly
529
            conda install -v -y $(ls ~/workspace/conda-bld/win-64/torchaudio*.tar.bz2)
moto's avatar
moto committed
530
      - checkout
531
532
533
534
535
      - run:
          name: smoke test
          command: |
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda activate python${PYTHON_VERSION}
536
            conda install 'ffmpeg<5'
moto's avatar
moto committed
537
            ./test/smoke_test/run_smoke_test.sh
538

539
540
541
542
543
  smoke_test_windows_conda_gpu:
    <<: *binary_common
    executor:
      name: windows-gpu
    steps:
Andrey Talman's avatar
Andrey Talman committed
544
      - checkout
545
546
547
548
      - attach_workspace:
          at: ~/workspace
      - designate_upload_channel
      - load_conda_channel_flags
Andrey Talman's avatar
Andrey Talman committed
549
550
551
552
      - windows_install_cuda
      - run:
          name: Update CUDA driver
          command: packaging/windows/internal/driver_update.bat
553
554
      - run:
          name: install binaries
Andrey Talman's avatar
Andrey Talman committed
555
          no_output_timeout: 30m
556
557
558
559
560
561
          command: |
            set -x
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda env remove -n python${PYTHON_VERSION} || true
            conda create -yn python${PYTHON_VERSION} python=${PYTHON_VERSION}
            conda activate python${PYTHON_VERSION}
Andrey Talman's avatar
Andrey Talman committed
562
            # Include numpy and cudatoolkit in the install conda-forge chanell is used for cudatoolkit
563

pbialecki's avatar
pbialecki committed
564
            if [[ "$CU_VERSION" == cu116 || "$CU_VERSION" == cu117 ]]; then
565
              conda install -v -y -c pytorch-${UPLOAD_CHANNEL} -c nvidia pytorch numpy ffmpeg pytorch-cuda=${CU_VERSION:2:2}.${CU_VERSION:4}
566
            else
567
              conda install -v -y -c pytorch-${UPLOAD_CHANNEL} pytorch numpy ffmpeg cudatoolkit=${CU_VERSION:2:2}.${CU_VERSION:4}
568
            fi
Andrey Talman's avatar
Andrey Talman committed
569
            # Install from torchaudio file
570
571
572
573
574
575
            conda install -v -y $(ls ~/workspace/conda-bld/win-64/torchaudio*.tar.bz2)
      - run:
          name: smoke test
          command: |
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda activate python${PYTHON_VERSION}
Andrey Talman's avatar
Andrey Talman committed
576
577
            # Install sound backend
            pip install PySoundFile
578
            # conda install 'ffmpeg<5'
moto's avatar
moto committed
579
            ./test/smoke_test/run_smoke_test.sh
580

581
582
583
584
585
586
587
  smoke_test_windows_pip:
    <<: *binary_common
    executor:
      name: windows-cpu
    steps:
      - attach_workspace:
          at: ~/workspace
588
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
589
      - load_conda_channel_flags
590
591
592
593
594
595
596
597
      - run:
          name: install binaries
          command: |
            set -x
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda env remove -n python${PYTHON_VERSION} || true
            conda create -yn python${PYTHON_VERSION} python=${PYTHON_VERSION}
            conda activate python${PYTHON_VERSION}
598
            pip install $(ls ~/workspace/torchaudio*.whl) -f "https://download.pytorch.org/whl/${UPLOAD_CHANNEL}/torch_${UPLOAD_CHANNEL}.html"
moto's avatar
moto committed
599
      - checkout
600
601
602
603
604
      - run:
          name: smoke test
          command: |
            eval "$('/C/tools/miniconda3/Scripts/conda.exe' 'shell.bash' 'hook')"
            conda activate python${PYTHON_VERSION}
605
606
607
608
609
610
            # Hack to load FFmpeg libraries
            # Note: Depending on Python version, they search different paths.
            # For 3.7 and 3.9, copying them in CWD works.
            cp ~/workspace/ffmpeg/bin/* test/smoke_test/
            # For 3.8 and 3.10, they must be in the same directory as the entrypoint lib
            cp ~/workspace/ffmpeg/bin/* /C/tools/miniconda3/envs/python${PYTHON_VERSION}/lib/site-packages/torchaudio/lib/
moto's avatar
moto committed
611
            ./test/smoke_test/run_smoke_test.sh
612

moto's avatar
moto committed
613
  unittest_linux_cpu:
moto's avatar
moto committed
614
615
    <<: *binary_common
    docker:
616
      - image: pytorch/torchaudio_unittest_base:manylinux-20210121
moto's avatar
moto committed
617
618
619
    resource_class: 2xlarge+
    steps:
      - checkout
620
621
      - attach_workspace:
          at: third_party
622
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
623
      - load_conda_channel_flags
624
625
626
627
628
629
      - run:
          name: Setup
          command: .circleci/unittest/linux/scripts/setup_env.sh
      - run:
          name: Install torchaudio
          command: .circleci/unittest/linux/scripts/install.sh
630
          environment:
631
              USE_FFMPEG: true
632
633
634
      - run:
          name: Run tests
          command: .circleci/unittest/linux/scripts/run_test.sh
moto's avatar
moto committed
635
636
          environment:
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CUDA: true
637
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_ON_PYTHON_310: true
638
639
      - store_test_results:
          path: test-results
640
641
      - store_artifacts:
          path: test/htmlcov
moto's avatar
moto committed
642
643
644
  unittest_linux_gpu:
    <<: *binary_common
    machine:
645
      image: ubuntu-2004-cuda-11.4:202110-01
646
    resource_class: gpu.nvidia.medium
moto's avatar
moto committed
647
    environment:
648
      <<: *environment
moto's avatar
moto committed
649
      image_name: pytorch/torchaudio_unittest_base:manylinux-cuda10.2-cudnn8-20210623
moto's avatar
moto committed
650
651
    steps:
      - checkout
652
653
      - attach_workspace:
          at: third_party
654
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
655
      - load_conda_channel_flags
656
657
658
      - run:
          name: Pull Docker image
          command: docker pull --quiet "${image_name}"
moto's avatar
moto committed
659
660
      - run:
          name: Setup
661
          command: docker run -t --gpus all -e PYTHON_VERSION -v $PWD:$PWD -w $PWD "${image_name}" .circleci/unittest/linux/scripts/setup_env.sh
moto's avatar
moto committed
662
663
      - run:
          name: Install torchaudio
moto's avatar
moto committed
664
          command: docker run -t --gpus all -e UPLOAD_CHANNEL -e CONDA_CHANNEL_FLAGS -e USE_FFMPEG=1 -v $PWD:$PWD -w $PWD "${image_name}" .circleci/unittest/linux/scripts/install.sh
moto's avatar
moto committed
665
666
      - run:
          name: Run tests
667
668
669
670
          environment:
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_ON_PYTHON_310: true
          command: |
            docker run -t --gpus all -v $PWD:$PWD -w $PWD -e "CI=${CI}" -e TORCHAUDIO_TEST_ALLOW_SKIP_IF_ON_PYTHON_310 "${image_name}" .circleci/unittest/linux/scripts/run_test.sh
moto's avatar
moto committed
671
672
      - store_test_results:
          path: test-results
673
674
      - store_artifacts:
          path: test/htmlcov
moto's avatar
moto committed
675
676

  unittest_windows_cpu:
677
678
679
    <<: *binary_common
    executor:
      name: windows-cpu
680
681
    steps:
      - checkout
682
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
683
      - load_conda_channel_flags
684
685
686
687
688
689
      - run:
          name: Setup
          command: .circleci/unittest/windows/scripts/setup_env.sh
      - run:
          name: Install torchaudio
          command: .circleci/unittest/windows/scripts/install.sh
690
          environment:
691
              USE_FFMPEG: true
692
693
694
      - run:
          name: Run tests
          command: .circleci/unittest/windows/scripts/run_test.sh
moto's avatar
moto committed
695
696
697
698
699
700
701
702
703
704
          environment:
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_APPLY_CMVN_SLIDING: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_FBANK_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_KALDI_PITCH_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_MFCC_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_SPECTROGRAM_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_SOX: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CUDA: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_KALDI: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_SOX: true
705
706
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_ON_PYTHON_310: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_MOD_sentencepiece: true
707
708
      - store_test_results:
          path: test-results
709
710
      - store_artifacts:
          path: test/htmlcov
711
712
713
714
715
716

  unittest_windows_gpu:
    <<: *binary_common
    executor:
      name: windows-gpu
    environment:
717
      <<: *environment
718
      CUDA_VERSION: "11.6"
719
720
    steps:
      - checkout
721
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
722
      - load_conda_channel_flags
moto's avatar
moto committed
723
724
      - run:
          name: Setup
725
          command: .circleci/unittest/windows/scripts/setup_env.sh
726
727
728
729
730
731
      - run:
          name: Install CUDA
          command: packaging/windows/internal/cuda_install.bat
      - run:
          name: Update CUDA driver
          command: packaging/windows/internal/driver_update.bat
moto's avatar
moto committed
732
      - run:
733
          name: Install torchaudio
734
          command: .circleci/unittest/windows/scripts/install.sh
735
          environment:
736
              USE_FFMPEG: true
moto's avatar
moto committed
737
      - run:
738
          name: Run tests
739
          command: .circleci/unittest/windows/scripts/run_test.sh
moto's avatar
moto committed
740
741
742
743
744
745
746
747
748
          environment:
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_APPLY_CMVN_SLIDING: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_FBANK_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_KALDI_PITCH_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_MFCC_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_SPECTROGRAM_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_SOX: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_KALDI: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_SOX: true
749
750
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_ON_PYTHON_310: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_MOD_sentencepiece: true
moto's avatar
moto committed
751
752
      - store_test_results:
          path: test-results
753
754
      - store_artifacts:
          path: test/htmlcov
moto's avatar
moto committed
755

moto's avatar
moto committed
756
757
758
  unittest_macos_cpu:
    <<: *binary_common
    macos:
759
      xcode: "14.0"
moto's avatar
moto committed
760
761
762
    resource_class: large
    steps:
      - checkout
Eli Uriegas's avatar
Eli Uriegas committed
763
      - load_conda_channel_flags
moto's avatar
moto committed
764
765
      - attach_workspace:
          at: third_party
766
      - designate_upload_channel
moto's avatar
moto committed
767
768
769
770
771
772
      - run:
          name: Setup
          command: .circleci/unittest/linux/scripts/setup_env.sh
      - run:
          name: Install torchaudio
          command: .circleci/unittest/linux/scripts/install.sh
773
          environment:
774
              USE_FFMPEG: true
moto's avatar
moto committed
775
              USE_OPENMP: false
moto's avatar
moto committed
776
777
778
      - run:
          name: Run tests
          command: .circleci/unittest/linux/scripts/run_test.sh
moto's avatar
moto committed
779
780
781
782
783
784
785
786
          environment:
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_APPLY_CMVN_SLIDING: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_FBANK_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_KALDI_PITCH_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_MFCC_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CMD_COMPUTE_SPECTROGRAM_FEATS: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_CUDA: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_QUANTIZATION: true
787
788
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_ON_PYTHON_310: true
              TORCHAUDIO_TEST_ALLOW_SKIP_IF_NO_MOD_sentencepiece: true
moto's avatar
moto committed
789
790
      - store_test_results:
          path: test-results
791
792
      - store_artifacts:
          path: test/htmlcov
moto's avatar
moto committed
793

794
795
796
797
798
799
800
  stylecheck:
    <<: *binary_common
    docker:
      - image: "pytorch/torchaudio_unittest_base:manylinux"
    resource_class: medium
    steps:
      - checkout
801
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
802
      - load_conda_channel_flags
803
804
805
806
807
808
809
      - run:
          name: Setup
          command: .circleci/unittest/linux/scripts/setup_env.sh
      - run:
          name: Run style check
          command: .circleci/unittest/linux/scripts/run_style_checks.sh

810
  build_docs:
811
    <<: *smoke_test_common
Sean Kim's avatar
Sean Kim committed
812
    resource_class: 2xlarge+
813
814
815
816
    steps:
      - attach_workspace:
          at: ~/workspace
      - checkout
817
      - designate_upload_channel
Eli Uriegas's avatar
Eli Uriegas committed
818
      - load_conda_channel_flags
819
      - run:
820
821
          name: Install packages
          command: |
822
823
            set -x
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
pbialecki's avatar
pbialecki committed
824
            if [[ "$CU_VERSION" == cu116 || "$CU_VERSION" == cu117  ]]; then
825
              conda install -v -y -c pytorch-${UPLOAD_CHANNEL} -c nvidia pytorch pytorch-cuda=${CU_VERSION:2:2}.${CU_VERSION:4}
moto's avatar
moto committed
826
            else
827
              conda install -v -y -c pytorch-${UPLOAD_CHANNEL} pytorch cudatoolkit=${CU_VERSION:2:2}.${CU_VERSION:4}
moto's avatar
moto committed
828
            fi
829
            conda install -v -y -c file://$HOME/workspace/conda-bld torchaudio
830
831
            # gxx_linux-64 is for installing pesq library that depends on cython
            conda install -y pandoc 'ffmpeg<5' gxx_linux-64
moto's avatar
moto committed
832
833
            apt update -qq && apt-get -qq install -y git make
            pip install --progress-bar off -r docs/requirements.txt -r docs/requirements-tutorials.txt
834
835
      - run:
          name: Build docs
836
          command: |
837
            source /usr/local/etc/profile.d/conda.sh && conda activate python${PYTHON_VERSION}
838
            cd docs
839
            make 'SPHINXOPTS=-W' html
840
841
842
            cd build
            tar -czf artifact.tar.gz html
            mv artifact.tar.gz html
843
844
          environment:
            BUILD_GALLERY: 1
moto's avatar
moto committed
845
            TORCH_SHOW_CPP_STACKTRACES: 1
846
          no_output_timeout: 30m
847
      - persist_to_workspace:
848
          root: ./
849
850
          paths:
            - "*"
851
852
853
      - store_artifacts:
          path: ./docs/build/html
          destination: docs
854
855
856
857
858
859
860
861
862

  upload_docs:
    <<: *binary_common
    docker:
      - image: "pytorch/manylinux-cuda100"
    resource_class: 2xlarge+
    steps:
      - attach_workspace:
          at: ~/workspace
863
864
865
866
867
868
869
870
871
872
      - run:
          name: Generate netrc
          command: |
            # set credentials for https pushing
            # requires the org-member context
            cat > ~/.netrc \<<DONE
              machine github.com
              login pytorchbot
              password ${GITHUB_PYTORCHBOT_TOKEN}
            DONE
873
874
875
      - run:
          name: Upload docs
          command: |
876
877
            # Don't use "checkout" step since it uses ssh, which cannot git push
            # https://circleci.com/docs/2.0/configuration-reference/#checkout
878
            set -ex
879
880
            # turn v1.12.0rc3 into 1.12.0
            tag=$(echo $CIRCLE_TAG | sed -e 's/v*\([0-9.]*\).*/\1/')
881
            target=${tag:-main}
Matti Picus's avatar
Matti Picus committed
882
            ~/workspace/.circleci/build_docs/commit_docs.sh ~/workspace $target
883

884
885
886
  docstring_parameters_sync:
    <<: *binary_common
    docker:
moto's avatar
moto committed
887
      - image: cimg/python:3.8
888
889
890
891
892
893
894
895
    steps:
      - checkout
      - run:
          name: Check parameters docstring sync
          command: |
            pip install --user pydocstyle
            pydocstyle torchaudio

Edward Z. Yang's avatar
Edward Z. Yang committed
896
workflows:
897
898
899
  lint:
    jobs:
      - lint_python_and_config
Edward Z. Yang's avatar
Edward Z. Yang committed
900
901
902
  build:
    jobs:
      - circleci_consistency
moto's avatar
moto committed
903
904
905
906
      {{ build_workflows() }}
  unittest:
    jobs:
      {{ unittest_workflows() }}
Edward Z. Yang's avatar
Edward Z. Yang committed
907
908
  nightly:
    jobs:
moto's avatar
moto committed
909
910
911
912
      - circleci_consistency:
          filters:
            branches:
              only: nightly
moto's avatar
moto committed
913
      {{ build_workflows(prefix="nightly_", filter_branch="nightly", upload=True) }}