2018-06-29 09:01:26 +02:00
|
|
|
*** settings ***
|
|
|
|
Resource ../../resources/Util.robot
|
|
|
|
|
|
|
|
*** Keywords ***
|
|
|
|
#for jsonpath refer to http://goessner.net/articles/JsonPath/ or https://nottyo.github.io/robotframework-jsonlibrary/JSONLibrary.html
|
|
|
|
|
|
|
|
Verify User
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify User..."
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
2018-06-29 09:01:26 +02:00
|
|
|
Switch To User Tag
|
2018-07-25 11:46:09 +02:00
|
|
|
@{user}= Get Value From Json ${json} $.users..name
|
|
|
|
:FOR ${user} IN @{user}
|
|
|
|
\ Page Should Contain ${user}
|
2018-06-29 09:01:26 +02:00
|
|
|
Logout Harbor
|
|
|
|
#verify user can login
|
2018-07-25 11:46:09 +02:00
|
|
|
@{user}= Get Value From Json ${json} $.users..name
|
|
|
|
:FOR ${user} IN @{user}
|
|
|
|
\ Sign In Harbor ${HARBOR_URL} ${user} ${HARBOR_PASSWORD}
|
2018-06-29 09:01:26 +02:00
|
|
|
\ Logout Harbor
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
2018-06-29 09:01:26 +02:00
|
|
|
|
|
|
|
Verify Project
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify Project..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:FOR ${project} IN @{project}
|
2019-10-29 11:18:05 +01:00
|
|
|
\ Retry Wait Until Page Contains ${project}
|
2019-09-24 12:35:19 +02:00
|
|
|
Verify Project Metadata ${json}
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
2018-06-29 09:01:26 +02:00
|
|
|
|
|
|
|
Verify Image Tag
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify Image Tag..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:FOR ${project} IN @{project}
|
2019-01-16 06:39:36 +01:00
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
2019-09-24 12:35:19 +02:00
|
|
|
\ @{repo}= Get Value From Json ${json} $.projects[?(@.name=${project})]..repo..name
|
|
|
|
\ Run Keyword If ${has_image} == ${true} Loop Image Repo @{repo}
|
2019-01-28 09:32:45 +01:00
|
|
|
\ Navigate To Projects
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
|
|
|
|
2019-09-24 12:35:19 +02:00
|
|
|
Verify Project Metadata
|
|
|
|
[Arguments] ${json}
|
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:FOR ${project} IN @{project}
|
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
|
|
|
\ Switch To Project Configuration
|
|
|
|
\ Verify Checkbox ${json} $.projects[?(@.name=${project})].configuration.public ${project_config_public_checkbox}
|
|
|
|
\ Verify Checkbox ${json} $.projects[?(@.name=${project})].configuration.enable_content_trust ${project_config_content_trust_checkbox}
|
2019-10-29 11:18:05 +01:00
|
|
|
\ Verify Checkbox ${json} $.projects[?(@.name=${project})].configuration.auto_scan ${project_config_scan_images_on_push_checkbox}
|
|
|
|
\ Verify Checkbox ${json} $.projects[?(@.name=${project})].configuration.prevent_vul ${project_config_prevent_vulnerable_images_from_running_checkbox}
|
2019-09-24 12:35:19 +02:00
|
|
|
\ ${ret} Get Selected List Value ${project_config_severity_select}
|
2019-10-29 11:18:05 +01:00
|
|
|
\ @{severity}= Get Value From Json ${json} $.projects[?(@.name=${project})].configuration.severity
|
2019-09-24 12:35:19 +02:00
|
|
|
\ Should Contain ${ret} @{severity}[0]
|
|
|
|
\ Navigate To Projects
|
|
|
|
Close Browser
|
|
|
|
|
|
|
|
Verify Checkbox
|
2020-01-10 07:40:02 +01:00
|
|
|
[Arguments] ${json} ${key} ${checkbox} ${is_opposite}=${false}
|
2019-09-24 12:35:19 +02:00
|
|
|
@{out}= Get Value From Json ${json} ${key}
|
2020-01-10 07:40:02 +01:00
|
|
|
${value}= Set Variable If '${is_opposite}'=='${true}' 'false' 'true'
|
|
|
|
Run Keyword If '@{out}[0]'==${value} Checkbox Should Be Selected ${checkbox}
|
2019-09-24 12:35:19 +02:00
|
|
|
... ELSE Checkbox Should Not Be Selected ${checkbox}
|
|
|
|
|
|
|
|
|
2018-07-25 11:46:09 +02:00
|
|
|
Loop Image Repo
|
|
|
|
[Arguments] @{repo}
|
|
|
|
:For ${repo} In @{repo}
|
|
|
|
\ Page Should Contain ${repo}
|
2018-06-29 09:01:26 +02:00
|
|
|
|
|
|
|
Verify Member Exist
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify Member Exist..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:For ${project} In @{project}
|
2019-01-16 06:39:36 +01:00
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
2018-06-29 09:01:26 +02:00
|
|
|
\ Switch To Member
|
2019-09-24 12:35:19 +02:00
|
|
|
\ @{members}= Get Value From Json ${json} $.projects[?(@.name=${project})].member..name
|
2018-07-25 11:46:09 +02:00
|
|
|
\ Loop Member @{members}
|
2019-01-28 09:32:45 +01:00
|
|
|
\ Navigate To Projects
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
|
|
|
|
2020-01-10 07:40:02 +01:00
|
|
|
Verify Webhook
|
|
|
|
[Arguments] ${json}
|
|
|
|
Log To Console "Verify Webhook..."
|
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:For ${project} In @{project}
|
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
|
|
|
\ Switch To Project Webhooks
|
|
|
|
\ @{enabled}= Get Value From Json ${json} $.projects[?(@.name=${project})].webhook.enabled
|
|
|
|
\ ${enable_count} Get Matching Xpath Count xpath=//span[contains(.,'Enabled')]
|
|
|
|
\ ${disable_count} Get Matching Xpath Count xpath=//span[contains(.,'Disabled')]
|
|
|
|
\ Log To Console '@{enabled}[0]'
|
|
|
|
\ Log To Console '${true}'
|
|
|
|
\ Run Keyword If '@{enabled}[0]' == '${true}' Page Should Contain Enabled
|
|
|
|
\ ... ELSE Page Should Contain Disabled
|
|
|
|
\ @{address}= Get Value From Json ${json} $.projects[?(@.name=${project})].webhook.address
|
|
|
|
\ Log To Console '@{address}[0]'
|
|
|
|
\ Page Should Contain @{address}[0]
|
|
|
|
\ Page Should Contain policy
|
|
|
|
\ Page Should Contain http
|
|
|
|
\ Navigate To Projects
|
|
|
|
Close Browser
|
|
|
|
|
|
|
|
Verify Tag Retention Rule
|
|
|
|
[Arguments] ${json}
|
|
|
|
Log To Console "Verify Tag Retention Rule..."
|
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:For ${project} In @{project}
|
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
|
|
|
\ Switch To Tag Retention
|
|
|
|
\ ${actions_count}= Set Variable 8
|
|
|
|
\ @{repository_patten}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_retention_rule.repository_patten
|
|
|
|
\ @{tag_decoration}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_retention_rule.tag_decoration
|
|
|
|
\ @{latestPushedK}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_retention_rule.latestPushedK
|
|
|
|
\ @{cron}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_retention_rule.cron
|
|
|
|
\ Log To Console '@{repository_patten}[0]'
|
|
|
|
\ Page Should Contain @{repository_patten}[0]
|
|
|
|
\ Page Should Contain @{tag_decoration}[0]
|
|
|
|
\ Page Should Contain @{latestPushedK}[0]
|
|
|
|
\ Page Should Contain @{cron}[0]
|
|
|
|
\ Navigate To Projects
|
|
|
|
Close Browser
|
|
|
|
|
|
|
|
Verify Tag Immutability Rule
|
|
|
|
[Arguments] ${json}
|
|
|
|
Log To Console "Verify Tag Immutability Rule..."
|
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:For ${project} In @{project}
|
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
|
|
|
\ Switch To Tag Immutability
|
|
|
|
\ @{repo_decoration}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_immutability_rule.repo_decoration
|
|
|
|
\ @{tag_decoration}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_immutability_rule.tag_decoration
|
|
|
|
\ @{repo_pattern}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_immutability_rule.repo_pattern
|
|
|
|
\ @{tag_pattern}= Get Value From Json ${json} $.projects[?(@.name=${project})].tag_immutability_rule.tag_pattern
|
|
|
|
\ Log To Console '@{repo_decoration}[0]'
|
|
|
|
#\ Page Should Contain @{repo_decoration}[0]
|
|
|
|
#\ Page Should Contain @{tag_decoration}[0]
|
|
|
|
\ Page Should Contain @{repo_pattern}[0]
|
|
|
|
\ Page Should Contain @{tag_pattern}[0]
|
|
|
|
\ Navigate To Projects
|
|
|
|
Close Browser
|
|
|
|
|
2018-07-25 11:46:09 +02:00
|
|
|
Loop Member
|
|
|
|
[Arguments] @{members}
|
|
|
|
:For ${member} In @{members}
|
|
|
|
\ Page Should Contain ${member}
|
2018-06-29 09:01:26 +02:00
|
|
|
|
2020-01-10 07:40:02 +01:00
|
|
|
Verify Robot Account Exist
|
|
|
|
[Arguments] ${json}
|
|
|
|
Log To Console "Verify Robot Account Exist..."
|
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:For ${project} In @{project}
|
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
|
|
|
\ Switch To Project Robot Account
|
|
|
|
\ @{robot_accounts}= Get Value From Json ${json} $.projects[?(@.name=${project})].robot_account..name
|
|
|
|
\ Loop Verify Robot Account @{robot_accounts}
|
|
|
|
\ Navigate To Projects
|
|
|
|
Close Browser
|
|
|
|
|
|
|
|
Loop Verify Robot Account
|
|
|
|
[Arguments] @{robot_accounts}
|
|
|
|
:For ${robot_account} In @{robot_accounts}
|
|
|
|
\ Page Should Contain ${robot_account}
|
|
|
|
|
2018-06-29 09:01:26 +02:00
|
|
|
Verify User System Admin Role
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify User System Admin Role..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{user}= Get Value From Json ${json} $.admin..name
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
:FOR ${user} IN @{user}
|
|
|
|
\ Sign In Harbor ${HARBOR_URL} ${user} ${HARBOR_PASSWORD}
|
2019-09-24 12:35:19 +02:00
|
|
|
\ Page Should Contain Administration
|
2018-06-29 09:01:26 +02:00
|
|
|
\ Logout Harbor
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
2019-09-24 12:35:19 +02:00
|
|
|
|
2018-06-29 09:01:26 +02:00
|
|
|
Verify System Label
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify System Label..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{label}= Get Value From Json ${json} $..syslabel..name
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
2018-06-29 09:01:26 +02:00
|
|
|
Switch To Configure
|
|
|
|
Switch To System Labels
|
2018-07-25 11:46:09 +02:00
|
|
|
:For ${label} In @{label}
|
|
|
|
\ Page Should Contain ${label}
|
|
|
|
Close Browser
|
2018-06-29 09:01:26 +02:00
|
|
|
|
|
|
|
Verify Project Label
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify Project Label..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{project}= Get Value From Json ${json} $.peoject.[*].name
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:For ${project} In @{project}
|
2019-01-16 06:39:36 +01:00
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
|
|
|
\ Switch To Project Label
|
|
|
|
\ @{projectlabel}= Get Value From Json ${json} $.projects[?(@.name=${project})]..labels..name
|
|
|
|
\ :For ${label} In @{label}
|
|
|
|
\ \ Page Should Contain ${projectlabel}
|
2019-01-28 09:32:45 +01:00
|
|
|
\ Navigate To Projects
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
2019-09-24 12:35:19 +02:00
|
|
|
|
2018-06-29 09:01:26 +02:00
|
|
|
Verify Endpoint
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify Endpoint..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{endpoint}= Get Value From Json ${json} $.endpoint..name
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
2018-06-29 09:01:26 +02:00
|
|
|
Switch To Registries
|
2018-07-25 11:46:09 +02:00
|
|
|
:For ${endpoint} In @{endpoint}
|
|
|
|
\ Page Should Contain ${endpoint}
|
|
|
|
Close Browser
|
2018-06-29 09:01:26 +02:00
|
|
|
|
|
|
|
Verify Replicationrule
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify Replicationrule..."
|
2019-10-29 11:18:05 +01:00
|
|
|
@{replicationrules}= Get Value From Json ${json} $.replicationrule.[*].rulename
|
|
|
|
@{endpoints}= Get Value From Json ${json} $.endpoint.[*].name
|
|
|
|
: FOR ${replicationrule} IN @{replicationrules}
|
|
|
|
\ Init Chrome Driver
|
|
|
|
\ Log To Console -----replicationrule-----"${replicationrule}"------------
|
|
|
|
\ Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
\ Switch To Replication Manage
|
|
|
|
\ Select Rule And Click Edit Button ${replicationrule}
|
|
|
|
\ @{is_src_registry}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].is_src_registry
|
|
|
|
\ @{trigger_type}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].trigger_type
|
|
|
|
\ @{name_filters}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].name_filters
|
|
|
|
\ @{tag_filters}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].tag_filters
|
|
|
|
\ @{dest_namespace}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].dest_namespace
|
|
|
|
\ @{cron}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].cron
|
|
|
|
\ @{is_src_registry}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].is_src_registry
|
|
|
|
\ Log To Console -----is_src_registry-----@{is_src_registry}[0]------------
|
|
|
|
\ @{endpoint}= Get Value From Json ${json} $.replicationrule[?(@.rulename=${replicationrule})].endpoint
|
|
|
|
\ Log To Console -----endpoint-----@{endpoint}------------
|
|
|
|
\ ${endpoint0}= Set Variable @{endpoint}[0]
|
|
|
|
\ Log To Console -----endpoint0-----${endpoint0}------------
|
|
|
|
\ @{endpoint_type}= Get Value From Json ${json} $.endpoint[?(@.name=${endpoint0})].type
|
|
|
|
\ Retry Textfield Value Should Be ${source_project} @{name_filters}[0]
|
|
|
|
\ Retry Textfield Value Should Be ${filter_tag} @{tag_filters}[0]
|
|
|
|
\ Retry Textfield Value Should Be ${rule_name_input} ${replicationrule}
|
|
|
|
\ Retry Textfield Value Should Be ${dest_namespace_xpath} @{dest_namespace}[0]
|
|
|
|
\ Log To Console -----endpoint_type-----@{endpoint_type}[0]------------
|
|
|
|
\ ${registry}= Set Variable If "@{endpoint_type}[0]"=="harbor" ${endpoint0}-https://${IP} ${endpoint0}-https://hub.docker.com
|
|
|
|
\ Log To Console -------registry---${registry}------------
|
|
|
|
\ Run Keyword If '@{is_src_registry}[0]' == '${true}' Retry List Selection Should Be ${src_registry_dropdown_list} ${registry}
|
|
|
|
\ ... ELSE Retry List Selection Should Be ${dest_registry_dropdown_list} ${registry}
|
|
|
|
\ #\ Retry List Selection Should Be ${rule_resource_selector} ${resource_type}
|
|
|
|
\ Retry List Selection Should Be ${rule_trigger_select} @{trigger_type}[0]
|
|
|
|
\ Run Keyword If '@{trigger_type}[0]' == 'scheduled' Log To Console ----------@{trigger_type}[0]------------
|
|
|
|
\ Run Keyword If '@{trigger_type}[0]' == 'scheduled' Retry Textfield Value Should Be ${targetCron_id} @{cron}[0]
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
2018-06-29 09:01:26 +02:00
|
|
|
|
|
|
|
Verify Project Setting
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify Project Setting..."
|
2018-06-29 09:01:26 +02:00
|
|
|
@{projects}= Get Value From Json ${json} $.projects.[*].name
|
2018-07-25 11:46:09 +02:00
|
|
|
:For ${project} In @{Projects}
|
|
|
|
\ ${public}= Get Value From Json ${json} $.projects[?(@.name=${project})].accesslevel
|
|
|
|
\ ${contenttrust}= Get Value From Json ${json} $.projects[?(@.name=${project})]..enable_content_trust
|
|
|
|
\ ${preventrunning}= Get Value From Json ${json} $.projects[?(@.name=${project})]..prevent_vulnerable_images_from_running
|
|
|
|
\ ${scanonpush}= Get Value From Json ${json} $.projects[?(@.name=${project})]..automatically_scan_images_on_push
|
2019-09-24 12:35:19 +02:00
|
|
|
\ Init Chrome Driver
|
2018-07-25 11:46:09 +02:00
|
|
|
\ Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
2019-01-16 06:39:36 +01:00
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
2018-06-29 09:01:26 +02:00
|
|
|
\ Goto Project Config
|
2018-12-29 10:01:43 +01:00
|
|
|
\ Run Keyword If ${public} == "public" Checkbox Should Be Checked //clr-checkbox-wrapper[@name='public']//label
|
|
|
|
\ Run Keyword If ${contenttrust} == "true" Checkbox Should Be Checked //clr-checkbox-wrapper[@name='content-trust']//label
|
|
|
|
\ Run Keyword If ${contenttrust} == "false" Checkbox Should Not Be Checked //clr-checkbox-wrapper[@name='content-trust']//label
|
2019-09-05 09:13:13 +02:00
|
|
|
\ Run Keyword If ${preventrunning} == "true" Checkbox Should Be Checked //*[@id='prevent-vulenrability-image']//clr-checkbox-wrapper//label
|
|
|
|
\ Run Keyword If ${preventrunning} == "false" Checkbox Should Not Be Checked //*[@id='prevent-vulenrability-image']//clr-checkbox-wrapper//label
|
2019-01-09 12:34:13 +01:00
|
|
|
\ Run Keyword If ${scanonpush} == "true" Checkbox Should Be Checked //clr-checkbox-wrapper[@id='scan-image-on-push-wrapper']//input
|
|
|
|
\ Run Keyword If ${scanonpush} == "true" Checkbox Should Not Be Checked //clr-checkbox-wrapper[@id='scan-image-on-push-wrapper']//input
|
2018-07-25 11:46:09 +02:00
|
|
|
\ Close Browser
|
2018-06-29 09:01:26 +02:00
|
|
|
|
2020-05-08 05:52:42 +02:00
|
|
|
Verify Interrogation Services
|
|
|
|
[Arguments] ${json}
|
|
|
|
Log To Console "Verify Interrogation Services..."
|
|
|
|
@{cron}= Get Value From Json ${json} $.interrogation_services..cron
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
Switch To Vulnerability Page
|
|
|
|
Page Should Contain Custom
|
|
|
|
Page Should Contain @{cron}[0]
|
|
|
|
Close Browser
|
|
|
|
|
2018-06-29 09:01:26 +02:00
|
|
|
Verify System Setting
|
2018-07-25 11:46:09 +02:00
|
|
|
[Arguments] ${json}
|
2020-01-10 07:40:02 +01:00
|
|
|
Log To Console "Verify System Setting..."
|
2018-07-25 11:46:09 +02:00
|
|
|
@{authtype}= Get Value From Json ${json} $.configuration.authmode
|
|
|
|
@{creation}= Get Value From Json ${json} $.configuration..projectcreation
|
|
|
|
@{selfreg}= Get Value From Json ${json} $.configuration..selfreg
|
|
|
|
@{emailserver}= Get Value From Json ${json} $.configuration..emailserver
|
|
|
|
@{emailport}= Get Value From Json ${json} $.configuration..emailport
|
|
|
|
@{emailuser}= Get Value From Json ${json} $.configuration..emailuser
|
|
|
|
@{emailfrom}= Get Value From Json ${json} $.configuration..emailfrom
|
|
|
|
@{token}= Get Value From Json ${json} $.configuration..token
|
2020-05-08 05:52:42 +02:00
|
|
|
@{robot_token}= Get Value From Json ${json} $.configuration..robot_token
|
2018-07-25 11:46:09 +02:00
|
|
|
@{scanschedule}= Get Value From Json ${json} $.configuration..scanall
|
2020-01-10 07:40:02 +01:00
|
|
|
@{cve_ids}= Get Value From Json ${json} $.configuration..cve
|
2018-07-25 11:46:09 +02:00
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
2018-06-29 09:01:26 +02:00
|
|
|
Switch To Configure
|
2018-07-25 11:46:09 +02:00
|
|
|
Page Should Contain @{authtype}[0]
|
2019-01-30 07:22:31 +01:00
|
|
|
Run Keyword If @{selfreg}[0] == 'True' Checkbox Should Be Checked //clr-checkbox-wrapper[@id='selfReg']//label
|
|
|
|
Run Keyword If @{selfreg}[0] == 'False' Checkbox Should Not Be Checked //clr-checkbox-wrapper[@id='selfReg']//label
|
2018-06-29 09:01:26 +02:00
|
|
|
Switch To Email
|
2019-01-30 07:22:31 +01:00
|
|
|
Textfield Value Should Be xpath=//*[@id='mailServer'] @{emailserver}[0]
|
|
|
|
Textfield Value Should Be xpath=//*[@id='emailPort'] @{emailport}[0]
|
|
|
|
Textfield Value Should Be xpath=//*[@id='emailUsername'] @{emailuser}[0]
|
|
|
|
Textfield Value Should Be xpath=//*[@id='emailFrom'] @{emailfrom}[0]
|
2018-06-29 09:01:26 +02:00
|
|
|
Switch To System Settings
|
2019-09-20 08:55:53 +02:00
|
|
|
${ret} Get Selected List Value xpath=//select[@id='proCreation']
|
|
|
|
Should Be Equal As Strings ${ret} @{creation}[0]
|
2018-07-25 11:46:09 +02:00
|
|
|
Token Must Be Match @{token}[0]
|
2020-05-08 05:52:42 +02:00
|
|
|
Robot Account Token Must Be Match @{robot_token}[0]
|
2018-07-25 11:46:09 +02:00
|
|
|
Close Browser
|
2018-06-29 09:01:26 +02:00
|
|
|
|
2020-01-10 07:40:02 +01:00
|
|
|
Verify Project-level Whitelist
|
|
|
|
[Arguments] ${json}
|
|
|
|
Log To Console "Verify Project-level Whitelist..."
|
|
|
|
@{project}= Get Value From Json ${json} $.projects.[*].name
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
:FOR ${project} IN @{project}
|
|
|
|
\ @{out_has_image}= Get Value From Json ${json} $.projects[?(@.name=${project})].has_image
|
|
|
|
\ ${has_image} Set Variable If @{out_has_image}[0] == ${true} ${true} ${false}
|
|
|
|
\ Go Into Project ${project} has_image=${has_image}
|
|
|
|
\ Switch To Project Configuration
|
|
|
|
\ @{is_reuse_sys_cve_whitelist}= Get Value From Json ${json} $.projects[?(@.name=${project})].configuration.reuse_sys_cve_whitelist
|
|
|
|
\ Run Keyword If "@{is_reuse_sys_cve_whitelist}[0]" == "true" Retry Wait Element Should Be Disabled ${project_config_project_wl_add_btn}
|
|
|
|
\ ... ELSE Retry Wait Element ${project_config_project_wl_add_btn}
|
|
|
|
\ @{cve_ids}= Get Value From Json ${json} $.projects[?(@.name=${project})].configuration.cve
|
|
|
|
\ Loop Verifiy CVE_IDs @{cve_ids}
|
|
|
|
\ Navigate To Projects
|
|
|
|
Close Browser
|
|
|
|
|
|
|
|
Loop Verifiy CVE_IDs
|
|
|
|
[Arguments] @{cve_ids}
|
|
|
|
:For ${cve_id} In @{cve_ids}
|
|
|
|
\ Page Should Contain ${cve_id}
|
|
|
|
|
|
|
|
Verify System Setting Whitelist
|
|
|
|
[Arguments] ${json}
|
|
|
|
Log To Console "Verify Verify System Setting Whitelist..."
|
|
|
|
@{cve_ids}= Get Value From Json ${json} $.configuration..cve..id
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
Switch To Configure
|
|
|
|
Switch To System Settings
|
|
|
|
Log To Console "@{cve_ids}"
|
|
|
|
Loop Verifiy CVE_IDs @{cve_ids}
|
|
|
|
Close Browser
|
|
|
|
|
|
|
|
Verify Clair Is Default Scanner
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
Switch To Scanners Page
|
|
|
|
Should Display The Default Clair Scanner
|
2020-05-08 05:52:42 +02:00
|
|
|
Close Browser
|
|
|
|
|
|
|
|
Verify Trivy Is Default Scanner
|
|
|
|
Init Chrome Driver
|
|
|
|
Sign In Harbor ${HARBOR_URL} ${HARBOR_ADMIN} ${HARBOR_PASSWORD}
|
|
|
|
Switch To Scanners Page
|
|
|
|
Should Display The Default Trivy Scanner
|
|
|
|
Close Browser
|