+++ mktemp -d ++ workdir=/tmp/tmp.C98Jy3nZEa ++ echo Workdir: /tmp/tmp.C98Jy3nZEa Workdir: /tmp/tmp.C98Jy3nZEa ++ echo Checkout base commit... Checkout base commit... ++ git checkout c0feaa4bdf3cf13ccd1e71816d02b6614cd78e29~1 Warning: you are leaving 2 commits behind, not connected to any of your branches: c0feaa4bd Merge 34c2f7aba12729ebd9e0896054af1be820eaeb5e into a261a76f57d5b7fdb848c02cf7695e053c07ff53 34c2f7aba initial If you want to keep them by creating a new branch, this may be a good time to do so with: git branch c0feaa4bd HEAD is now at a261a76f5 Refactoring parsing of nodes info response from cluster (#11681) ++ echo Build graph for base commit... Build graph for base commit... ++ ./ya make -Gj0 -ttt ydb --build release -k --cache-tests --build-all ++ jq '.graph[]' Downloading https://devtools-registry.s3.yandex.net/7434979108 [...........................................] OK ++ echo Checkout head commit... Checkout head commit... ++ git checkout c0feaa4bdf3cf13ccd1e71816d02b6614cd78e29 Previous HEAD position was a261a76f5 Refactoring parsing of nodes info response from cluster (#11681) HEAD is now at c0feaa4bd Merge 34c2f7aba12729ebd9e0896054af1be820eaeb5e into a261a76f57d5b7fdb848c02cf7695e053c07ff53 ++ echo Build graph for head commit... Build graph for head commit... ++ jq '.graph[]' ++ ./ya make -Gj0 -ttt ydb --build release -k --cache-tests --build-all ++ echo Generate lists of uids for base and head... Generate lists of uids for base and head... ++ cat /tmp/tmp.C98Jy3nZEa/graph_base ++ jq .uid ++ cat /tmp/tmp.C98Jy3nZEa/graph_head ++ jq .uid ++ echo Create a list of changed uids in the head graph... Create a list of changed uids in the head graph... ++ sort ++ cat /tmp/tmp.C98Jy3nZEa/uid_head ++ uniq -d ++ cat /tmp/tmp.C98Jy3nZEa/uid_base ++ sort ++ uniq -u ++ cat /tmp/tmp.C98Jy3nZEa/uid_head ++ echo Create ya.make Create ya.make ++ echo '' ++ echo Generate list of test shard names from the head graph based on the list of uids... Generate list of test shard names from the head graph based on the list of uids... ++ cat /tmp/tmp.C98Jy3nZEa/graph_head ++ jq -r --slurpfile uids /tmp/tmp.C98Jy3nZEa/uids_new 'select( ."node-type"=="test") | select( any( .uid; .==$uids[] )) | .kv.path' ++ sort ++ uniq ++ echo Number of test suites: Number of test suites: ++ cat /tmp/tmp.C98Jy3nZEa/testsuites ++ wc -l 75 ++ echo Removing test suite name from the list to get target names... Removing test suite name from the list to get target names... ++ sed -E 's/\/[^/]*$//g;/^null$/d' /tmp/tmp.C98Jy3nZEa/testsuites ++ echo Append into ya.make RECURSE_FOR_TESTS to all required tests... Append into ya.make RECURSE_FOR_TESTS to all required tests... ++ cat /tmp/tmp.C98Jy3nZEa/ts2 ++ echo 'RECURSE_FOR_TESTS(' ++ cat ++ echo ')' ++ echo Generate list of module names from the head graph based on the list of uids... Generate list of module names from the head graph based on the list of uids... ++ cat /tmp/tmp.C98Jy3nZEa/graph_head ++ jq -r --slurpfile uids /tmp/tmp.C98Jy3nZEa/uids_new 'select( ."target_properties"."module_type" != null) | select( ( ."target_properties"."module_tag" // "-" | strings | contains("proto") ) | not ) | select( any( .uid; .==$uids[] )) | .target_properties.module_dir' ++ uniq ++ sort ++ echo Number of modules: Number of modules: ++ cat /tmp/tmp.C98Jy3nZEa/modules ++ wc -l 1 ++ echo Filter only modules in ydb Filter only modules in ydb ++ cat /tmp/tmp.C98Jy3nZEa/modules ++ grep '^ydb' ++ echo Number of modules: Number of modules: ++ cat /tmp/tmp.C98Jy3nZEa/modules2 ++ wc -l 1 ++ echo Append into ya.make RECURSE to all required modules... Append into ya.make RECURSE to all required modules... ++ cat /tmp/tmp.C98Jy3nZEa/modules2 ++ echo 'RECURSE(' ++ cat ++ echo ')' ++ echo 'ya.make content:' ya.make content: ++ cat ya.make RECURSE_FOR_TESTS( ydb/library/yql/tests/sql/dq_file/part0 ydb/library/yql/tests/sql/dq_file/part10 ydb/library/yql/tests/sql/dq_file/part11 ydb/library/yql/tests/sql/dq_file/part12 ydb/library/yql/tests/sql/dq_file/part13 ydb/library/yql/tests/sql/dq_file/part14 ydb/library/yql/tests/sql/dq_file/part15 ydb/library/yql/tests/sql/dq_file/part16 ydb/library/yql/tests/sql/dq_file/part17 ydb/library/yql/tests/sql/dq_file/part18 ydb/library/yql/tests/sql/dq_file/part19 ydb/library/yql/tests/sql/dq_file/part1 ydb/library/yql/tests/sql/dq_file/part2 ydb/library/yql/tests/sql/dq_file/part3 ydb/library/yql/tests/sql/dq_file/part4 ydb/library/yql/tests/sql/dq_file/part5 ydb/library/yql/tests/sql/dq_file/part6 ydb/library/yql/tests/sql/dq_file/part7 ydb/library/yql/tests/sql/dq_file/part8 ydb/library/yql/tests/sql/dq_file/part9 ydb/library/yql/tests/sql/hybrid_file/part0 ydb/library/yql/tests/sql/hybrid_file/part10 ydb/library/yql/tests/sql/hybrid_file/part1 ydb/library/yql/tests/sql/hybrid_file/part2 ydb/library/yql/tests/sql/hybrid_file/part3 ydb/library/yql/tests/sql/hybrid_file/part4 ydb/library/yql/tests/sql/hybrid_file/part5 ydb/library/yql/tests/sql/hybrid_file/part6 ydb/library/yql/tests/sql/hybrid_file/part7 ydb/library/yql/tests/sql/hybrid_file/part8 ydb/library/yql/tests/sql/hybrid_file/part9 ydb/library/yql/tests/sql/solomon ydb/library/yql/tests/sql/solomon ydb/library/yql/tests/sql/sql2yql ydb/library/yql/tests/sql/yt_native_file/part0 ydb/library/yql/tests/sql/yt_native_file/part10 ydb/library/yql/tests/sql/yt_native_file/part11 ydb/library/yql/tests/sql/yt_native_file/part12 ydb/library/yql/tests/sql/yt_native_file/part13 ydb/library/yql/tests/sql/yt_native_file/part14 ydb/library/yql/tests/sql/yt_native_file/part15 ydb/library/yql/tests/sql/yt_native_file/part16 ydb/library/yql/tests/sql/yt_native_file/part17 ydb/library/yql/tests/sql/yt_native_file/part18 ydb/library/yql/tests/sql/yt_native_file/part19 ydb/library/yql/tests/sql/yt_native_file/part1 ydb/library/yql/tests/sql/yt_native_file/part2 ydb/library/yql/tests/sql/yt_native_file/part3 ydb/library/yql/tests/sql/yt_native_file/part4 ydb/library/yql/tests/sql/yt_native_file/part5 ydb/library/yql/tests/sql/yt_native_file/part6 ydb/library/yql/tests/sql/yt_native_file/part7 ydb/library/yql/tests/sql/yt_native_file/part8 ydb/library/yql/tests/sql/yt_native_file/part9 ydb/tests/fq/yt/kqp_yt_file/part0 ydb/tests/fq/yt/kqp_yt_file/part10 ydb/tests/fq/yt/kqp_yt_file/part11 ydb/tests/fq/yt/kqp_yt_file/part12 ydb/tests/fq/yt/kqp_yt_file/part13 ydb/tests/fq/yt/kqp_yt_file/part14 ydb/tests/fq/yt/kqp_yt_file/part15 ydb/tests/fq/yt/kqp_yt_file/part16 ydb/tests/fq/yt/kqp_yt_file/part17 ydb/tests/fq/yt/kqp_yt_file/part18 ydb/tests/fq/yt/kqp_yt_file/part19 ydb/tests/fq/yt/kqp_yt_file/part1 ydb/tests/fq/yt/kqp_yt_file/part2 ydb/tests/fq/yt/kqp_yt_file/part3 ydb/tests/fq/yt/kqp_yt_file/part4 ydb/tests/fq/yt/kqp_yt_file/part5 ydb/tests/fq/yt/kqp_yt_file/part6 ydb/tests/fq/yt/kqp_yt_file/part7 ydb/tests/fq/yt/kqp_yt_file/part8 ydb/tests/fq/yt/kqp_yt_file/part9 ) RECURSE( ydb/library/yql/tests/sql/solomon )