X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=scripts%2Fci.sh;h=2dd5e25cebad049b4ab172d902a5e82b491431c8;hb=1db86422eb516acd23550f30536de4ebd8f0daea;hp=7ad6f38e95f5e5f5be740f8edf4dc0ccf0461d94;hpb=9b3294a8496c89c7880054de1f1f09c9990f1b46;p=github%2FChocobozzz%2FPeerTube.git diff --git a/scripts/ci.sh b/scripts/ci.sh index 7ad6f38e9..2dd5e25ce 100755 --- a/scripts/ci.sh +++ b/scripts/ci.sh @@ -8,6 +8,7 @@ if [ $# -eq 0 ]; then fi retries=3 +speedFactor="${2:-1}" runTest () { jobname=$1 @@ -23,7 +24,7 @@ runTest () { joblog="$jobname-ci.log" parallel -j $jobs --retries $retries \ - "echo Trying {} >> $joblog; npm run mocha -- -c --timeout 30000 --exit --require ./dist/server/tests/register.js --bail {}" \ + "echo Trying {} >> $joblog; npm run mocha -- -c --timeout 30000 --exit --bail {}" \ ::: $files cat "$joblog" | uniq -c @@ -40,17 +41,20 @@ findTestFiles () { find $1 -type f -name "*.js" $exception | xargs echo } -if [ "$1" = "client" ]; then +if [ "$1" = "types-package" ]; then + npm run generate-types-package 0.0.0 + npm run tsc -- --noEmit --esModuleInterop packages/types/tests/test.ts +elif [ "$1" = "client" ]; then npm run build feedsFiles=$(findTestFiles ./dist/server/tests/feeds) helperFiles=$(findTestFiles ./dist/server/tests/helpers) libFiles=$(findTestFiles ./dist/server/tests/lib) miscFiles="./dist/server/tests/client.js ./dist/server/tests/misc-endpoints.js" - # Not in plugin task, it needs an index.html - pluginFiles="./dist/server/tests/plugins/html-injection.js" + # Not in their own task, they need an index.html + pluginFiles="./dist/server/tests/plugins/html-injection.js ./dist/server/tests/api/server/plugins.js" - MOCHA_PARALLEL=true runTest "$1" 2 $feedsFiles $helperFiles $miscFiles $pluginFiles $libFiles + MOCHA_PARALLEL=true runTest "$1" $((2*$speedFactor)) $feedsFiles $helperFiles $miscFiles $pluginFiles $libFiles elif [ "$1" = "cli-plugin" ]; then npm run build:server npm run setup:cli @@ -58,7 +62,7 @@ elif [ "$1" = "cli-plugin" ]; then pluginsFiles=$(findTestFiles ./dist/server/tests/plugins html-injection.js) cliFiles=$(findTestFiles ./dist/server/tests/cli) - MOCHA_PARALLEL=true runTest "$1" 2 $pluginsFiles + MOCHA_PARALLEL=true runTest "$1" $((2*$speedFactor)) $pluginsFiles runTest "$1" 1 $cliFiles elif [ "$1" = "api-1" ]; then npm run build:server @@ -67,21 +71,22 @@ elif [ "$1" = "api-1" ]; then notificationsFiles=$(findTestFiles ./dist/server/tests/api/notifications) searchFiles=$(findTestFiles ./dist/server/tests/api/search) - MOCHA_PARALLEL=true runTest "$1" 3 $notificationsFiles $searchFiles $checkParamFiles + MOCHA_PARALLEL=true runTest "$1" $((3*$speedFactor)) $notificationsFiles $searchFiles $checkParamFiles elif [ "$1" = "api-2" ]; then npm run build:server liveFiles=$(findTestFiles ./dist/server/tests/api/live) - serverFiles=$(findTestFiles ./dist/server/tests/api/server) + serverFiles=$(findTestFiles ./dist/server/tests/api/server plugins.js) usersFiles=$(findTestFiles ./dist/server/tests/api/users) - MOCHA_PARALLEL=true runTest "$1" 3 $liveFiles $serverFiles $usersFiles + MOCHA_PARALLEL=true runTest "$1" $((3*$speedFactor)) $liveFiles $serverFiles $usersFiles elif [ "$1" = "api-3" ]; then npm run build:server videosFiles=$(findTestFiles ./dist/server/tests/api/videos) + viewsFiles=$(findTestFiles ./dist/server/tests/api/views) - MOCHA_PARALLEL=true runTest "$1" 3 $videosFiles + MOCHA_PARALLEL=true runTest "$1" $((3*$speedFactor)) $viewsFiles $videosFiles elif [ "$1" = "api-4" ]; then npm run build:server @@ -90,7 +95,13 @@ elif [ "$1" = "api-4" ]; then objectStorageFiles=$(findTestFiles ./dist/server/tests/api/object-storage) activitypubFiles=$(findTestFiles ./dist/server/tests/api/activitypub) - MOCHA_PARALLEL=true runTest "$1" 2 $moderationFiles $redundancyFiles $activitypubFiles $objectStorageFiles + MOCHA_PARALLEL=true runTest "$1" $((2*$speedFactor)) $moderationFiles $redundancyFiles $activitypubFiles $objectStorageFiles +elif [ "$1" = "api-5" ]; then + npm run build:server + + transcodingFiles=$(findTestFiles ./dist/server/tests/api/transcoding) + + MOCHA_PARALLEL=true runTest "$1" $((2*$speedFactor)) $transcodingFiles elif [ "$1" = "external-plugins" ]; then npm run build:server @@ -98,8 +109,6 @@ elif [ "$1" = "external-plugins" ]; then runTest "$1" 1 $externalPluginsFiles elif [ "$1" = "lint" ]; then - npm run build:server - npm run eslint -- --ext .ts "./server/**/*.ts" "shared/**/*.ts" "scripts/**/*.ts" npm run swagger-cli -- validate support/doc/api/openapi.yaml