summaryrefslogtreecommitdiffstats
path: root/jjb/kvmfornfv/kvmfornfv-upload-artifact.sh
blob: 91b6f448133b64fa9b8f7cd49f17621ab670f973 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
#!/bin/bash
set -o nounset

if [[ "$JOB_NAME" =~ (verify|merge|daily|weekly) ]]; then
    JOB_TYPE=${BASH_REMATCH[0]}
else
    echo "Unable to determine job type!"
    exit 1
fi

case "$JOB_TYPE" in
    verify)
       OPNFV_ARTIFACT_VERSION="gerrit-$GERRIT_CHANGE_NUMBER"
       GS_UPLOAD_LOCATION="gs://artifacts.opnfv.org/$PROJECT/review/$GERRIT_CHANGE_NUMBER"
       echo "Removing outdated artifacts produced for the previous patch for the change $GERRIT_CHANGE_NUMBER"
       gsutil ls $GS_UPLOAD_LOCATION > /dev/null 2>&1 && gsutil rm -r $GS_UPLOAD_LOCATION
       echo "Uploading artifacts for the change $GERRIT_CHANGE_NUMBER. This could take some time..."
       ;;
    daily)
        echo "Uploading daily artifacts This could take some time..."
        OPNFV_ARTIFACT_VERSION=$(date -u +"%Y-%m-%d_%H-%M-%S")
        GS_UPLOAD_LOCATION="gs://$GS_URL/$OPNFV_ARTIFACT_VERSION"
        GS_LOG_LOCATION="gs://$GS_URL/logs-$(date -u +"%Y-%m-%d")"/
        ;;
    *)
        echo "Artifact upload is not enabled for $JOB_TYPE jobs"
        exit 1
esac

# save information regarding artifacts into file
(
    echo "OPNFV_ARTIFACT_VERSION=$OPNFV_ARTIFACT_VERSION"
    echo "OPNFV_GIT_URL=$(git config --get remote.origin.url)"
    echo "OPNFV_GIT_SHA1=$(git rev-parse HEAD)"
    echo "OPNFV_ARTIFACT_URL=$GS_UPLOAD_LOCATION"
    echo "OPNFV_BUILD_URL=$BUILD_URL"
) > $WORKSPACE/opnfv.properties
source $WORKSPACE/opnfv.properties

# upload artifacts
if [[ "$PHASE" == "build" ]]; then
    gsutil cp -r $WORKSPACE/build_output/* $GS_UPLOAD_LOCATION > $WORKSPACE/gsutil.log 2>&1
    gsutil -m setmeta -r \
        -h "Cache-Control:private, max-age=0, no-transform" \
        $GS_UPLOAD_LOCATION > /dev/null 2>&1
else
    if [[ "$JOB_TYPE" == "daily" ]]; then
        log_dir=$WORKSPACE/build_output/log
        if [[ -d "$log_dir" ]]; then
            #Uploading logs to artifacts
            echo "Uploading artifacts for future debugging needs...."
            gsutil cp -r $WORKSPACE/build_output/log-*.tar.gz $GS_LOG_LOCATION > $WORKSPACE/gsutil.log 2>&1
            # verifying the logs uploaded by cyclictest daily test job
            gsutil ls $GS_LOG_LOCATION > /dev/null 2>&1
            if [[ $? -ne 0 ]]; then
                echo "Problem while uploading logs to artifacts!"
                echo "Check log $WORKSPACE/gsutil.log on $NODE_NAME"
                exit 1
            fi
        else
            echo "No test logs/artifacts available for uploading"
        fi
    fi
fi

# upload metadata file for the artifacts built by daily job
if [[ "$JOB_TYPE" == "daily" && "$PHASE" == "build" ]]; then
    gsutil cp $WORKSPACE/opnfv.properties $GS_UPLOAD_LOCATION/opnfv.properties > $WORKSPACE/gsutil.log 2>&1
    gsutil cp $WORKSPACE/opnfv.properties gs://$GS_URL/latest.properties > $WORKSPACE/gsutil.log 2>&1
    gsutil -m setmeta -r \
        -h "Cache-Control:private, max-age=0, no-transform" \
        $GS_UPLOAD_LOCATION/opnfv.properties \
        gs://$GS_URL/latest.properties > /dev/null 2>&1
fi

# verifying the artifacts uploading by verify/daily build job
if [[ "$PHASE" == "build" ]]; then
    gsutil ls $GS_UPLOAD_LOCATION > /dev/null 2>&1
    if [[ $? -ne 0 ]]; then
        echo "Problem while uploading artifacts!"
        echo "Check log $WORKSPACE/gsutil.log on $NODE_NAME"
        exit 1
    fi
fi
echo "Uploaded artifacts!"
/span>: astute[key] = fuel_conf[key] if require_network_restart: admin_ifcfg = '/etc/sysconfig/network-scripts/ifcfg-eth0' exec_cmd('echo "DEFROUTE=no" >> %s' % admin_ifcfg) log('At least one interface was reconfigured, restart network manager') exec_cmd('systemctl restart network') return astute def transplant_bootstrap(astute, fuel_bootstrap_cli): if 'BOOTSTRAP' in astute: for skey in astute['BOOTSTRAP'].iterkeys(): # FIXME: astute.yaml repos point to public ones instead of # local mirrors, this filter should be removed when in sync if skey != 'repos': fuel_bootstrap_cli[skey] = astute['BOOTSTRAP'][skey] return fuel_bootstrap_cli def main(): dea_file = parse_arguments() check_file_exists(ASTUTE_YAML) check_file_exists(FUEL_BOOTSTRAP_CLI_YAML) dea = DeploymentEnvironmentAdapter(dea_file) log('Reading astute file %s' % ASTUTE_YAML) with io.open(ASTUTE_YAML) as stream: astute = yaml.load(stream) log('Initiating transplant') transplant(dea, astute) with io.open(ASTUTE_YAML, 'w') as stream: yaml.dump(astute, stream, default_flow_style=False) log('Transplant done') # Update bootstrap config yaml with info from DEA/astute.yaml with io.open(FUEL_BOOTSTRAP_CLI_YAML) as stream: fuel_bootstrap_cli = yaml.load(stream) transplant_bootstrap(astute, fuel_bootstrap_cli) with io.open(FUEL_BOOTSTRAP_CLI_YAML, 'w') as stream: yaml.dump(fuel_bootstrap_cli, stream, default_flow_style=False) if __name__ == '__main__': main()