| Anna Arhipova | 7717848 | 2023-06-14 11:46:42 +0200 | [diff] [blame] | 1 | #!/bin/bash | 
| Anna Arhipova | d2ced49 | 2022-09-28 10:02:56 +0200 | [diff] [blame] | 2 | # export REMOTE_JENKINS='172.19.112.216' | 
| Vladimir Khlyunev | 211b24d | 2023-06-27 19:51:50 +0400 | [diff] [blame] | 3 | set -eox pipefail; | 
| Vladimir Khlyunev | a960a38 | 2023-06-27 20:14:25 +0400 | [diff] [blame^] | 4 | # Temporary call to global SCRIPT_JENKINS_IP while migrating jenkins | 
|  | 5 | export REMOTE_JENKINS="${SCRIPT_JENKINS_IP:-sre-ci.scc.mirantis.net}" | 
| Anna Arhipova | d2ced49 | 2022-09-28 10:02:56 +0200 | [diff] [blame] | 6 |  | 
|  | 7 | if [ ! -n "$LAB_CONTEXT_NAME" ]; then | 
|  | 8 | echo 'LAB_CONTEXT_NAME is not set! | 
|  | 9 | This name will be used: | 
|  | 10 | - to find the template file tcp_tests/templates/cookied-model-generator/salt_${LAB_CONTEXT_NAME}.yaml | 
|  | 11 | - to set the salt model cluster name | 
|  | 12 | - to make DOMAIN_NAME=${LAB_CONTEXT_NAME}.local | 
|  | 13 | '; | 
|  | 14 | exit 1 | 
|  | 15 | fi | 
|  | 16 |  | 
|  | 17 |  | 
|  | 18 | if [ -n "$TCP_QA_REVIEW" ]; then | 
|  | 19 | git fetch https://gerrit.mcp.mirantis.com/mcp/tcp-qa $TCP_QA_REVIEW && git checkout FETCH_HEAD | 
|  | 20 | fi | 
|  | 21 |  | 
|  | 22 | . ${VENV_PATH}/bin/activate | 
|  | 23 |  | 
|  | 24 | if [ "$ERASE_EXISTING_ENVIRONMENT" = "true" ]; then | 
|  | 25 | dos.py erase $ENV_NAME || true | 
|  | 26 | fi | 
|  | 27 |  | 
|  | 28 | cd tcp_tests | 
|  | 29 |  | 
|  | 30 | sed -i 's/%LOGIN%/rHm22xBV9K/' templates/${LAB_CONTEXT_NAME}/salt-context-cookiecutter* | 
|  | 31 | sed -i 's/%PASS%/az9Gq7Wq4jRic29YWP/' templates/${LAB_CONTEXT_NAME}/salt-context-cookiecutter* | 
|  | 32 |  | 
|  | 33 | rm -f ./*.tar.gz | 
|  | 34 |  | 
|  | 35 | #MODEL_FILENAME=model_${CLUSTER_NAME}_${BUILD_NUMBER}.tar.gz | 
|  | 36 | MODEL_FILENAME=model_${ENV_NAME}.tar.gz | 
|  | 37 | if [[ -f $MODEL_FILENAME ]]; then | 
|  | 38 | rm $MODEL_FILENAME | 
|  | 39 | fi | 
|  | 40 |  | 
|  | 41 | #################### | 
|  | 42 | # Generate the model | 
|  | 43 | git config  user.name "tester" | 
|  | 44 | git config  user.email "tester@example.com" | 
|  | 45 |  | 
|  | 46 | py.test --junit-xml=deploy_generate_model.xml -k ${TEST_GROUP} | 
|  | 47 |  | 
|  | 48 |  | 
|  | 49 | ######################################################## | 
|  | 50 | # Upload the generated model to the repository on cz8133 | 
|  | 51 |  | 
|  | 52 | # Create a directory where the created model will be unpacked | 
|  | 53 | rm -rf ./model | 
|  | 54 | mkdir -p ./model | 
|  | 55 |  | 
|  | 56 | eval $(ssh-agent) | 
|  | 57 | ssh-add ${COOKIECUTTER_TEMPLATES_REPOSITORY_KEY_PATH} | 
|  | 58 |  | 
|  | 59 | # Create remote repository | 
|  | 60 | ssh jenkins@${REMOTE_JENKINS} " | 
|  | 61 | if [[ ! -d /home/jenkins/salt-models/${LAB_CONTEXT_NAME}.git ]]; then | 
|  | 62 | mkdir -p /home/jenkins/salt-models/${LAB_CONTEXT_NAME}.git; | 
|  | 63 | cd /home/jenkins/salt-models/${LAB_CONTEXT_NAME}.git; | 
|  | 64 | git init --bare; | 
|  | 65 | cp hooks/post-update.sample hooks/post-update; | 
|  | 66 | fi" | 
|  | 67 |  | 
|  | 68 | cd ./model | 
|  | 69 |  | 
|  | 70 | # Prepare the repository in the ./model | 
|  | 71 | git init | 
|  | 72 | git remote add integration ssh://jenkins@${REMOTE_JENKINS}/home/jenkins/salt-models/${LAB_CONTEXT_NAME}.git | 
|  | 73 | git pull integration ${REPOSITORY_SUITE} || true | 
|  | 74 | git checkout -b ${REPOSITORY_SUITE} | 
|  | 75 | git rm -rf . || true   # remove previous content from the working dir | 
|  | 76 |  | 
|  | 77 | # unpack new model into ./model dir | 
|  | 78 | tar -xzf ../${MODEL_FILENAME} -C ./ | 
|  | 79 | # Add reclass-system submodule | 
|  | 80 | git submodule add https://gerrit.mcp.mirantis.com/salt-models/reclass-system classes/system/ | 
|  | 81 | cd classes/system | 
|  | 82 | git checkout ${SALT_MODELS_SYSTEM_COMMIT} | 
|  | 83 | cd ../.. | 
|  | 84 |  | 
|  | 85 | # The directory "classes/service" is created at bootstrap time | 
|  | 86 | # and cannot be commited to the repository automatically. | 
|  | 87 | # It is not needed in the repo because contains only symlinks. | 
|  | 88 | cat << EOF > ./.gitignore | 
|  | 89 | classes/service | 
|  | 90 | EOF | 
|  | 91 |  | 
|  | 92 | # create a commit with new model (if any change exists) | 
|  | 93 | git add -A | 
|  | 94 | git commit -m "${LAB_CONTEXT_NAME}@${REPOSITORY_SUITE} generated at $(date +%Y-%m-%d/%H-%M) | 
|  | 95 |  | 
|  | 96 | REPOSITORY_SUITE=${REPOSITORY_SUITE} | 
|  | 97 | SALT_MODELS_SYSTEM_COMMIT=${SALT_MODELS_SYSTEM_COMMIT} | 
|  | 98 | COOKIECUTTER_TEMPLATE_COMMIT=${COOKIECUTTER_TEMPLATE_COMMIT} | 
|  | 99 | " | 
|  | 100 |  | 
|  | 101 | # Push new commit to the ${REMOTE_JENKINS} repository | 
|  | 102 | git push integration ${REPOSITORY_SUITE} | 
|  | 103 |  | 
|  | 104 | echo "######################################################################################################################" | 
|  | 105 | echo "#" | 
|  | 106 | echo "# Clone the model into the tests:  git clone http://${REMOTE_JENKINS}:8098/${LAB_CONTEXT_NAME}.git -b ${REPOSITORY_SUITE}" | 
|  | 107 | echo "#" | 
|  | 108 | echo "######################################################################################################################" | 
|  | 109 |  |