You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

dockerci.sh 3.3 kB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. #!/bin/bash
  2. MODELSCOPE_CACHE_DIR_IN_CONTAINER=/modelscope_cache
  3. CODE_DIR=$PWD
  4. CODE_DIR_IN_CONTAINER=/Maas-lib
  5. echo "$USER"
  6. gpus='0,1 2,3 4,5 6,7'
  7. cpu_sets='45-58 31-44 16-30 0-15'
  8. cpu_sets_arr=($cpu_sets)
  9. is_get_file_lock=false
  10. CI_COMMAND='bash .dev_scripts/ci_container_test.sh python tests/run.py --parallel 2 --run_config tests/run_config.yaml'
  11. echo "ci command: $CI_COMMAND"
  12. idx=0
  13. for gpu in $gpus
  14. do
  15. exec {lock_fd}>"/tmp/gpu$gpu" || exit 1
  16. flock -n "$lock_fd" || { echo "WARN: gpu $gpu is in use!" >&2; idx=$((idx+1)); continue; }
  17. echo "get gpu lock $gpu"
  18. CONTAINER_NAME="modelscope-ci-$idx"
  19. let is_get_file_lock=true
  20. # pull image if there are update
  21. docker pull ${IMAGE_NAME}:${IMAGE_VERSION}
  22. if [ "$MODELSCOPE_SDK_DEBUG" == "True" ]; then
  23. echo 'debugging'
  24. docker run --rm --name $CONTAINER_NAME --shm-size=16gb \
  25. --cpuset-cpus=${cpu_sets_arr[$idx]} \
  26. --gpus='"'"device=$gpu"'"' \
  27. -v $CODE_DIR:$CODE_DIR_IN_CONTAINER \
  28. -v $MODELSCOPE_CACHE:$MODELSCOPE_CACHE_DIR_IN_CONTAINER \
  29. -v $MODELSCOPE_HOME_CACHE/$idx:/root \
  30. -v /home/admin/pre-commit:/home/admin/pre-commit \
  31. -e CI_TEST=True \
  32. -e TEST_LEVEL=$TEST_LEVEL \
  33. -e MODELSCOPE_CACHE=$MODELSCOPE_CACHE_DIR_IN_CONTAINER \
  34. -e MODELSCOPE_DOMAIN=$MODELSCOPE_DOMAIN \
  35. -e MODELSCOPE_SDK_DEBUG=True \
  36. -e HUB_DATASET_ENDPOINT=$HUB_DATASET_ENDPOINT \
  37. -e TEST_ACCESS_TOKEN_CITEST=$TEST_ACCESS_TOKEN_CITEST \
  38. -e TEST_ACCESS_TOKEN_SDKDEV=$TEST_ACCESS_TOKEN_SDKDEV \
  39. -e TEST_LEVEL=$TEST_LEVEL \
  40. -e MODELSCOPE_ENVIRONMENT='ci' \
  41. -e TEST_UPLOAD_MS_TOKEN=$TEST_UPLOAD_MS_TOKEN \
  42. -e MODEL_TAG_URL=$MODEL_TAG_URL \
  43. --workdir=$CODE_DIR_IN_CONTAINER \
  44. ${IMAGE_NAME}:${IMAGE_VERSION} \
  45. $CI_COMMAND
  46. else
  47. docker run --rm --name $CONTAINER_NAME --shm-size=16gb \
  48. --cpuset-cpus=${cpu_sets_arr[$idx]} \
  49. --gpus='"'"device=$gpu"'"' \
  50. -v $CODE_DIR:$CODE_DIR_IN_CONTAINER \
  51. -v $MODELSCOPE_CACHE:$MODELSCOPE_CACHE_DIR_IN_CONTAINER \
  52. -v $MODELSCOPE_HOME_CACHE/$idx:/root \
  53. -v /home/admin/pre-commit:/home/admin/pre-commit \
  54. -e CI_TEST=True \
  55. -e TEST_LEVEL=$TEST_LEVEL \
  56. -e MODELSCOPE_CACHE=$MODELSCOPE_CACHE_DIR_IN_CONTAINER \
  57. -e MODELSCOPE_DOMAIN=$MODELSCOPE_DOMAIN \
  58. -e HUB_DATASET_ENDPOINT=$HUB_DATASET_ENDPOINT \
  59. -e TEST_ACCESS_TOKEN_CITEST=$TEST_ACCESS_TOKEN_CITEST \
  60. -e TEST_ACCESS_TOKEN_SDKDEV=$TEST_ACCESS_TOKEN_SDKDEV \
  61. -e TEST_LEVEL=$TEST_LEVEL \
  62. -e MODELSCOPE_ENVIRONMENT='ci' \
  63. -e TEST_UPLOAD_MS_TOKEN=$TEST_UPLOAD_MS_TOKEN \
  64. -e MODEL_TAG_URL=$MODEL_TAG_URL \
  65. --workdir=$CODE_DIR_IN_CONTAINER \
  66. ${IMAGE_NAME}:${IMAGE_VERSION} \
  67. $CI_COMMAND
  68. fi
  69. if [ $? -ne 0 ]; then
  70. echo "Running test case failed, please check the log!"
  71. exit -1
  72. fi
  73. break
  74. done
  75. if [ "$is_get_file_lock" = false ] ; then
  76. echo 'No free GPU!'
  77. exit 1
  78. fi