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 2.0 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  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='7 6 5 4 3 2 1 0'
  7. cpu_sets='0-7 8-15 16-23 24-30 31-37 38-44 45-51 52-58'
  8. cpu_sets_arr=($cpu_sets)
  9. is_get_file_lock=false
  10. # export RUN_CASE_COMMAND='python tests/run.py --run_config tests/run_config.yaml'
  11. CI_COMMAND=${CI_COMMAND:-bash .dev_scripts/ci_container_test.sh $RUN_CASE_BASE_COMMAND}
  12. echo "ci command: $CI_COMMAND"
  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; continue; }
  17. echo "get gpu lock $gpu"
  18. CONTAINER_NAME="modelscope-ci-$gpu"
  19. let is_get_file_lock=true
  20. # pull image if there are update
  21. docker pull ${IMAGE_NAME}:${IMAGE_VERSION}
  22. docker run --rm --name $CONTAINER_NAME --shm-size=16gb \
  23. --cpuset-cpus=${cpu_sets_arr[$gpu]} \
  24. --gpus="device=$gpu" \
  25. -v $CODE_DIR:$CODE_DIR_IN_CONTAINER \
  26. -v $MODELSCOPE_CACHE:$MODELSCOPE_CACHE_DIR_IN_CONTAINER \
  27. -v $MODELSCOPE_HOME_CACHE/$gpu:/root \
  28. -v /home/admin/pre-commit:/home/admin/pre-commit \
  29. -e CI_TEST=True \
  30. -e TEST_LEVEL=$TEST_LEVEL \
  31. -e MODELSCOPE_CACHE=$MODELSCOPE_CACHE_DIR_IN_CONTAINER \
  32. -e MODELSCOPE_DOMAIN=$MODELSCOPE_DOMAIN \
  33. -e HUB_DATASET_ENDPOINT=$HUB_DATASET_ENDPOINT \
  34. -e TEST_ACCESS_TOKEN_CITEST=$TEST_ACCESS_TOKEN_CITEST \
  35. -e TEST_ACCESS_TOKEN_SDKDEV=$TEST_ACCESS_TOKEN_SDKDEV \
  36. -e TEST_LEVEL=$TEST_LEVEL \
  37. -e TEST_UPLOAD_MS_TOKEN=$TEST_UPLOAD_MS_TOKEN \
  38. -e MODEL_TAG_URL=$MODEL_TAG_URL \
  39. --workdir=$CODE_DIR_IN_CONTAINER \
  40. --net host \
  41. ${IMAGE_NAME}:${IMAGE_VERSION} \
  42. $CI_COMMAND
  43. if [ $? -ne 0 ]; then
  44. echo "Running test case failed, please check the log!"
  45. exit -1
  46. fi
  47. break
  48. done
  49. if [ "$is_get_file_lock" = false ] ; then
  50. echo 'No free GPU!'
  51. exit 1
  52. fi