mirror of
https://github.com/goharbor/harbor.git
synced 2024-12-05 00:23:33 +01:00
4d31de1d5e
Signed-off-by: danfengliu <danfengl@vmware.com>
288 lines
14 KiB
Plaintext
288 lines
14 KiB
Plaintext
// 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 Harbor BATs
|
|
Library ../../apitests/python/library/Harbor.py ${SERVER_CONFIG}
|
|
Resource ../../resources/Util.robot
|
|
Default Tags Replication
|
|
|
|
*** Variables ***
|
|
${HARBOR_URL} https://${ip}
|
|
${SSH_USER} root
|
|
${HARBOR_ADMIN} admin
|
|
${SERVER} ${ip}
|
|
${SERVER_URL} https://${SERVER}
|
|
${SERVER_API_ENDPOINT} ${SERVER_URL}/api
|
|
&{SERVER_CONFIG} endpoint=${SERVER_API_ENDPOINT} verify_ssl=False
|
|
${REMOTE_SERVER} ${ip1}
|
|
${REMOTE_SERVER_URL} https://${REMOTE_SERVER}
|
|
${REMOTE_SERVER_API_ENDPOINT} ${REMOTE_SERVER_URL}/api
|
|
|
|
*** Test Cases ***
|
|
Test Case - Get Harbor Version
|
|
#Just get harbor version and log it
|
|
Get Harbor Version
|
|
|
|
Test Case - Pro Replication Rules Add
|
|
Init Chrome Driver
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Switch To Replication Manage
|
|
Check New Rule UI Without Endpoint
|
|
Close Browser
|
|
|
|
Test Case - Harbor Endpoint Verification
|
|
#This case need vailid info and selfsign cert
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Switch To Registries
|
|
Create A New Endpoint harbor edp1${d} https://${ip} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} N
|
|
Endpoint Is Pingable
|
|
Enable Certificate Verification
|
|
Endpoint Is Unpingable
|
|
Close Browser
|
|
|
|
Test Case - DockerHub Endpoint Add
|
|
#This case need vailid info and selfsign cert
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Switch To Registries
|
|
Create A New Endpoint docker-hub edp1${d} https://hub.docker.com/ danfengliu Aa123456 Y
|
|
Close Browser
|
|
|
|
Test Case - Harbor Endpoint Add
|
|
#This case need vailid info and selfsign cert
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Registries
|
|
Create A New Endpoint harbor testabc https://${ip} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} Y
|
|
Close Browser
|
|
|
|
Test Case - Harbor Endpoint Edit
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Registries
|
|
Rename Endpoint testabc deletea
|
|
Retry Wait Until Page Contains deletea
|
|
Close Browser
|
|
|
|
Test Case - Harbor Endpoint Delete
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Registries
|
|
Delete Endpoint deletea
|
|
Delete Success deletea
|
|
Close Browser
|
|
|
|
Test Case - Replication Rule Edit
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
${endpoint1}= Set Variable e1${d}
|
|
${endpoint2}= Set Variable e2${d}
|
|
${rule_name_old}= Set Variable rule_testabc${d}
|
|
${rule_name_new}= Set Variable rule_abctest${d}
|
|
${resource_type}= Set Variable chart
|
|
${dest_namespace}= Set Variable dest_namespace${d}
|
|
${mode}= Set Variable Scheduled
|
|
${cron_str}= Set Variable 10 10 10 * * *
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Registries
|
|
Create A New Endpoint docker-hub ${endpoint1} https://hub.docker.com/ danfengliu Aa123456 Y
|
|
Create A New Endpoint harbor ${endpoint2} https://${ip} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} Y
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint ${rule_name_old} pull danfengliu/* image ${endpoint1} project${d}
|
|
Edit Replication Rule By Name ${rule_name_old}
|
|
# Change rule-name, source-registry, filter, trigger-mode for edition verification
|
|
Clear Field Of Characters ${rule_name_input} 30
|
|
Retry Text Input ${rule_name_input} ${rule_name_new}
|
|
Select Source Registry ${endpoint2}
|
|
#Source Resource Filter
|
|
Retry Text Input ${source_project} project${d}
|
|
Select From List By Value ${rule_resource_selector} ${resource_type}
|
|
Retry Text Input ${dest_namespace_xpath} ${dest_namespace}
|
|
Select Trigger ${mode}
|
|
Retry Text Input ${targetCron_id} ${cron_str}
|
|
Retry Double Keywords When Error Retry Element Click ${rule_save_button} Retry Wait Until Page Not Contains Element ${rule_save_button}
|
|
# verify all items were changed as expected
|
|
Edit Replication Rule By Name ${rule_name_new}
|
|
Retry Textfield Value Should Be ${rule_name_input} ${rule_name_new}
|
|
Retry List Selection Should Be ${src_registry_dropdown_list} ${endpoint2}-https://${ip}
|
|
Retry Textfield Value Should Be ${source_project} project${d}
|
|
Retry Textfield Value Should Be ${dest_namespace_xpath} ${dest_namespace}
|
|
Retry List Selection Should Be ${rule_resource_selector} ${resource_type}
|
|
Retry List Selection Should Be ${rule_trigger_select} ${mode}
|
|
Retry Textfield Value Should Be ${targetCron_id} ${cron_str}
|
|
Retry Element Click ${rule_cancel_btn}
|
|
Ensure Delete Replication Rule By Name ${rule_name_new}
|
|
Close Browser
|
|
|
|
Test Case - Replication Rule Delete
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
${endpoint1}= Set Variable e1${d}
|
|
${rule_name}= Set Variable rule_testabc${d}
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Registries
|
|
Create A New Endpoint docker-hub ${endpoint1} https://hub.docker.com/ danfengliu Aa123456 Y
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint ${rule_name} pull danfengliu/* image ${endpoint1} project${d}
|
|
Ensure Delete Replication Rule By Name ${rule_name}
|
|
Close Browser
|
|
|
|
Test Case - Replication Of Pull Images from DockerHub To Self
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
#login source
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Create An New Project project${d}
|
|
Switch To Registries
|
|
Create A New Endpoint docker-hub e${d} https://hub.docker.com/ danfengliu Aa123456 Y
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint rule${d} pull danfengliu/* image e${d} project${d}
|
|
Select Rule And Replicate rule${d}
|
|
#In docker-hub, under repository danfengliu, there're only 2 images: centos,mariadb.
|
|
Image Should Be Replicated To Project project${d} centos
|
|
Image Should Be Replicated To Project project${d} mariadb
|
|
Close Browser
|
|
|
|
Test Case - Replication Of Push Images from Self To Harbor
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
#login source
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Create An New Project project${d}
|
|
Push Image ${ip} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} project${d} hello-world
|
|
Push Image ${ip} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} project${d} busybox:latest
|
|
Push Image With Tag ${ip} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} project${d} hello-world v1
|
|
Switch To Registries
|
|
Create A New Endpoint harbor e${d} https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint rule${d} push project${d}/* image e${d} project_dest${d}
|
|
#logout and login target
|
|
Logout Harbor
|
|
Sign In Harbor https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Create An New Project project_dest${d}
|
|
#logout and login source
|
|
Logout Harbor
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Switch To Replication Manage
|
|
Select Rule And Replicate rule${d}
|
|
Sleep 20
|
|
Logout Harbor
|
|
Sign In Harbor https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Image Should Be Replicated To Project project_dest${d} hello-world
|
|
Image Should Be Replicated To Project project_dest${d} busybox
|
|
Close Browser
|
|
|
|
Test Case - Replication Of Push Chart from Self To Harbor
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
#login source
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Create An New Project project${d}
|
|
Go Into Project project${d} has_image=${false}
|
|
Switch To Project Charts
|
|
Upload Chart files
|
|
Switch To Registries
|
|
Create A New Endpoint harbor e${d} https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint rule${d} push project${d}/* chart e${d} project_dest${d}
|
|
#logout and login target
|
|
Logout Harbor
|
|
Sign In Harbor https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Create An New Project project_dest${d}
|
|
#logout and login source
|
|
Logout Harbor
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Switch To Replication Manage
|
|
Select Rule And Replicate rule${d}
|
|
Sleep 20
|
|
Logout Harbor
|
|
Sign In Harbor https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Go Into Project project_dest${d} has_image=${false}
|
|
Switch To Project Charts
|
|
Go Into Chart Version ${harbor_chart_name}
|
|
Retry Wait Until Page Contains ${harbor_chart_version}
|
|
Go Into Chart Detail ${harbor_chart_version}
|
|
Close Browser
|
|
|
|
Test Case - Replication Of Push Images from Self To Harbor By Push Event
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
#login source
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Create An New Project project${d}
|
|
Switch To Registries
|
|
Create A New Endpoint harbor e${d} https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint rule${d} push project${d}/* image e${d} project_dest${d}
|
|
... Event Based
|
|
#logout and login target
|
|
Logout Harbor
|
|
Sign In Harbor https://${ip1} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} is_close_scan_plugin_mesg=${true}
|
|
Click Element If Visible ${close_scan_plugin_mesg}
|
|
Create An New Project project_dest${d}
|
|
Push Image ${ip} ${HARBOR_ADMIN} ${HARBOR_PASSWORD} project${d} centos
|
|
Image Should Be Replicated To Project project_dest${d} centos
|
|
Close Browser
|
|
|
|
Test Case - Replication Of Pull Images from AWS-ECR To Self
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
#login source
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Create An New Project project${d}
|
|
Switch To Registries
|
|
Create A New Endpoint aws-ecr e${d} us-east-2 ${ecr_ac_id} ${ecr_ac_key} Y
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint rule${d} pull a/* image e${d} project${d}
|
|
Select Rule And Replicate rule${d}
|
|
Image Should Be Replicated To Project project${d} httpd
|
|
Image Should Be Replicated To Project project${d} alpine
|
|
Image Should Be Replicated To Project project${d} hello-world
|
|
Close Browser
|
|
|
|
Test Case - Replication Of Pull Images from Google-GCR To Self
|
|
Init Chrome Driver
|
|
${d}= Get Current Date result_format=%m%s
|
|
#login source
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
Create An New Project project${d}
|
|
Switch To Registries
|
|
Create A New Endpoint google-gcr e${d} asia.gcr.io ${null} ${gcr_ac_key} Y
|
|
Switch To Replication Manage
|
|
Create A Rule With Existing Endpoint rule${d} pull eminent-nation-87317/* image e${d} project${d}
|
|
Filter Replicatin Rule rule${d}
|
|
Select Rule And Replicate rule${d}
|
|
Image Should Be Replicated To Project project${d} httpd
|
|
Image Should Be Replicated To Project project${d} tomcat
|
|
Close Browser
|