# Copyright Project Harbor Authors # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License *** Settings *** Documentation This resource provides any keywords related to the Harbor private registry appliance Library SeleniumLibrary Library OperatingSystem *** Variables *** *** Keywords *** Install Harbor to Test Server Log To Console \nStart Docker Daemon Start Docker Daemon Locally Sleep 5s ${rc} ${output}= Run And Return Rc And Output docker ps Should Be Equal As Integers ${rc} 0 Log To Console ${output} Log To Console \nconfig harbor cfg Config Harbor cfg http_proxy=https Prepare Cert Log To Console \ncomplile and up harbor now Compile and Up Harbor With Source Code ${rc} ${output}= Run And Return Rc And Output docker ps Should Be Equal As Integers ${rc} 0 Log To Console ${output} Generate Certificate Authority For Chrome Up Harbor [Arguments] ${with_notary}=true ${with_chartmuseum}=true ${rc} ${output}= Run And Return Rc And Output make start -e NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} Log ${rc} Log ${output} Should Be Equal As Integers ${rc} 0 Down Harbor [Arguments] ${with_notary}=true ${with_chartmuseum}=true ${rc} ${output}= Run And Return Rc And Output echo "Y" | make down -e NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} Log ${rc} Log ${output} Should Be Equal As Integers ${rc} 0 Package Harbor Offline [Arguments] ${with_notary}=true ${with_chartmuseum}=true ${with_trivy}=true Log To Console \nStart Docker Daemon Start Docker Daemon Locally Log To Console make package_offline GOBUILDTAGS="include_oss include_gcs" BASEIMAGETAG=%{Harbor_Build_Base_Tag} NPM_REGISTRY=%{NPM_REGISTRY} VERSIONTAG=%{Harbor_Assets_Version} PKGVERSIONTAG=%{Harbor_Package_Version} NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} TRIVYFLAG=${with_trivy} HTTPPROXY= ${rc} ${output}= Run And Return Rc And Output make package_offline GOBUILDTAGS="include_oss include_gcs" BASEIMAGETAG=%{Harbor_Build_Base_Tag} NPM_REGISTRY=%{NPM_REGISTRY} VERSIONTAG=%{Harbor_Assets_Version} PKGVERSIONTAG=%{Harbor_Package_Version} NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} TRIVYFLAG=${with_trivy} HTTPPROXY= Log To Console ${rc} Log To Console ${output} Should Be Equal As Integers ${rc} 0 Package Harbor Online [Arguments] ${with_notary}=true ${with_chartmuseum}=true ${with_trivy}=true Log To Console \nStart Docker Daemon Start Docker Daemon Locally Log To Console \nmake package_online GOBUILDTAGS="include_oss include_gcs" VERSIONTAG=%{Harbor_Assets_Version} PKGVERSIONTAG=%{Harbor_Package_Version} NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} TRIVYFLAG=${with_trivy} HTTPPROXY= ${rc} ${output}= Run And Return Rc And Output make package_online GOBUILDTAGS="include_oss include_gcs" VERSIONTAG=%{Harbor_Assets_Version} PKGVERSIONTAG=%{Harbor_Package_Version} NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} TRIVYFLAG=${with_trivy} HTTPPROXY= Log ${rc} Log ${output} Should Be Equal As Integers ${rc} 0 Switch To LDAP Down Harbor ${rc} ${output}= Run And Return Rc And Output rm -rf /data Log ${rc} Should Be Equal As Integers ${rc} 0 Prepare Cert Config Harbor cfg auth=ldap_auth http_proxy=https Prepare Up Harbor Docker Pull osixia/openldap:1.1.7 ${rc} ${output}= Run And Return Rc And Output cd tests && ./ldapprepare.sh Log ${rc} Log ${output} Should Be Equal As Integers ${rc} 0 ${rc} ${output}= Run And Return Rc And Output docker ps Log ${output} Should Be Equal As Integers ${rc} 0 Generate Certificate Authority For Chrome Get Harbor CA [Arguments] ${ip} ${cert} Log All Start to get harbor ca: ${ip} ${cert} Run Keyword If '${http_get_ca}' == 'false' Run Keywords ... Wait Unitl Command Success cp /ca/harbor_ca.crt ${cert} ... AND Return From Keyword ${rc} ${output}= Run And Return Rc And Output rm -rf ~/.docker/ Log All ${rc} ${rc} ${output}= Run And Return Rc and Output curl -o ${cert} -s -k -X GET -u 'admin:Harbor12345' 'https://${ip}/api/v2.0/systeminfo/getcert' Log All ${output} Should Be Equal As Integers ${rc} 0 Enable Notary Client ${rc} ${output}= Run And Return Rc And Output rm -rf ~/.docker/ Log ${rc} ${rc} ${output}= Run And Return Rc and Output curl -o /notary_ca.crt -s -k -X GET -u 'admin:Harbor12345' 'https://${ip}/api/v2.0/systeminfo/getcert' Log ${output} Should Be Equal As Integers ${rc} 0 Notary Remove Signature [Arguments] ${ip} ${project} ${image} ${tag} ${user} ${pwd} ${rc} ${output}= Run And Return Rc And Output ./tests/robot-cases/Group0-Util/notary-util.sh remove ${ip} ${project} ${image} ${tag} ${notaryServerEndpoint} ${user} ${pwd} Log To Console ${output} Log ${output} Should Be Equal As Integers ${rc} 0 Notary Key Rotate [Arguments] ${ip} ${project} ${image} ${tag} ${user} ${pwd} ${rc} ${output}= Run And Return Rc And Output ./tests/robot-cases/Group0-Util/notary-util.sh key_rotate ${ip} ${project} ${image} ${tag} ${notaryServerEndpoint} ${user} ${pwd} Log To Console ${output} Log ${output} Should Be Equal As Integers ${rc} 0 Prepare [Arguments] ${with_notary}=true ${with_chartmuseum}=true ${rc} ${output}= Run And Return Rc And Output make prepare -e NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} Log ${rc} Log ${output} Should Be Equal As Integers ${rc} 0 Config Harbor cfg # Will change the IP and Protocol in the harbor.cfg [Arguments] ${http_proxy}=http ${auth}=db_auth ${rc} ${output}= Run And Return Rc And Output ip addr s eth0 |grep "inet "|awk '{print $2}' |awk -F "/" '{print $1}' ${rc}= Run And Return Rc sed "s/^hostname = .*/hostname = ${output}/g" -i ./make/harbor.cfg Log ${rc} Should Be Equal As Integers ${rc} 0 ${rc}= Run And Return Rc sed "s/^ui_url_protocol = .*/ui_url_protocol = ${http_proxy}/g" -i ./make/harbor.cfg Log ${rc} Should Be Equal As Integers ${rc} 0 ${rc}= Run And Return Rc sed "s/^auth_mode = .*/auth_mode = ${auth}/g" -i ./make/harbor.cfg Log ${rc} Should Be Equal As Integers ${rc} 0 ${out}= Run cat ./make/harbor.cfg Log ${out} Prepare Cert # Will change the IP and Protocol in the harbor.cfg ${rc} ${ip}= Run And Return Rc And Output ip addr s eth0 |grep "inet "|awk '{print $2}' |awk -F "/" '{print $1}' Log ${ip} ${rc}= Run And Return Rc sed "s/^IP=.*/IP=${ip}/g" -i ./tests/generateCerts.sh Log ${rc} ${out}= Run cat ./tests/generateCerts.sh Log ${out} ${rc} ${output}= Run And Return Rc And Output ./tests/generateCerts.sh Should Be Equal As Integers ${rc} 0 Compile and Up Harbor With Source Code [Arguments] ${with_notary}=true ${with_chartmuseum}=true ${rc} ${output}= Run And Return Rc And Output make install swagger_client NOTARYFLAG=${with_notary} CHARTFLAG=${with_chartmuseum} HTTPPROXY= Log ${output} Should Be Equal As Integers ${rc} 0 Sleep 20 Wait for Harbor Ready [Arguments] ${protocol} ${HARBOR_IP} Log To Console Waiting for Harbor to Come Up... FOR ${i} IN RANGE 20 ${out}= Run curl -k ${protocol}://${HARBOR_IP} Log ${out} ${status}= Run Keyword And Return Status Should Not Contain ${out} 502 Bad Gateway ${status}= Run Keyword If ${status} Run Keyword And Return Status Should Not Contain ${out} Connection refused ${status}= Run Keyword If ${status} Run Keyword And Return Status Should Contain ${out} Harbor Return From Keyword If ${status} ${HARBOR_IP} Sleep 30s END Fail Harbor failed to come up properly! Get Harbor Version ${rc} ${output}= Run And Return Rc And Output curl -k -X GET --header 'Accept: application/json' 'https://${ip}/api/v2.0/systeminfo'|grep -i harbor_version Log To Console ${output}