Commit 1cb0dc20 authored by Mark Lapierre's avatar Mark Lapierre

Merge branch 'qa-jl-geo-wiki-repl-spec' into 'master'

Geo: Test wiki replication via HTTP

See merge request gitlab-org/gitlab-ee!15504
parents 019f1e14 9141628d
...@@ -74,7 +74,7 @@ module QA ...@@ -74,7 +74,7 @@ module QA
context 'git-lfs commit' do context 'git-lfs commit' do
it 'is replicated to the secondary' do it 'is replicated to the secondary' do
file_content = 'This is a Geo project!' file_content = 'This is a Geo project!'
lfs_file_content = 'The rendered file could not be displayed because it is stored in LFS.' lfs_file_display_message = 'The rendered file could not be displayed because it is stored in LFS.'
project = nil project = nil
Runtime::Browser.visit(:geo_primary, QA::Page::Main::Login) do Runtime::Browser.visit(:geo_primary, QA::Page::Main::Login) do
...@@ -103,7 +103,7 @@ module QA ...@@ -103,7 +103,7 @@ module QA
show.wait_for_repository_replication show.wait_for_repository_replication
expect(page).to have_content(file_name) expect(page).to have_content(file_name)
expect(page).to have_content(lfs_file_content) expect(page).to have_content(lfs_file_display_message)
end end
end end
...@@ -127,7 +127,7 @@ module QA ...@@ -127,7 +127,7 @@ module QA
show.wait_for_repository_replication_with(file_name) show.wait_for_repository_replication_with(file_name)
expect(page).to have_content(file_name) expect(page).to have_content(file_name)
expect(page).to have_content(lfs_file_content) expect(page).to have_content(lfs_file_display_message)
end end
end end
end end
......
# frozen_string_literal: true
module QA
context 'Geo', :orchestrated, :geo do
describe 'GitLab wiki HTTP push' do
after do
# Log out so subsequent tests can start unauthenticated
Runtime::Browser.visit(:geo_secondary, QA::Page::Dashboard::Projects)
Page::Main::Menu.perform do |menu|
menu.sign_out if menu.has_personal_area?(wait: 0)
end
end
context 'wiki commit' do
it 'is replicated to the secondary node' do
wiki_title = 'Geo Replication Wiki'
wiki_content = 'This tests replication of wikis via HTTP'
push_content = 'This is from the Geo wiki push!'
project_name = "geo-wiki-project-#{SecureRandom.hex(8)}"
# Create new wiki and push wiki commit
Runtime::Browser.visit(:geo_primary, QA::Page::Main::Login) do
Page::Main::Login.perform(&:sign_in_using_credentials)
project = Resource::Project.fabricate! do |project|
project.name = project_name
project.description = 'Geo project for wiki repo test'
end
wiki = Resource::Wiki.fabricate! do |wiki|
wiki.project = project
wiki.title = wiki_title
wiki.content = wiki_content
wiki.message = 'First commit'
end
expect(page).to have_content(wiki_content)
Resource::Repository::WikiPush.fabricate! do |push|
push.wiki = wiki
push.file_name = 'Home.md'
push.file_content = push_content
push.commit_message = 'Update Home.md'
end
Page::Project::Menu.perform(&:click_wiki)
expect(page).to have_content(push_content)
end
# Validate that wiki is synced on secondary node
Runtime::Browser.visit(:geo_secondary, QA::Page::Main::Login) do
Page::Main::Login.perform(&:sign_in_using_credentials)
EE::Page::Main::Banner.perform do |banner|
expect(banner).to have_secondary_read_only_banner
end
Page::Main::Menu.perform do |menu|
menu.go_to_projects
end
Page::Dashboard::Projects.perform do |dashboard|
dashboard.wait_for_project_replication(project_name)
dashboard.go_to_project(project_name)
end
Page::Project::Menu.perform(&:click_wiki)
Page::Project::Wiki::Show.perform do |show|
expect(page).to have_content(wiki_title)
expect(page).to have_content(push_content)
end
end
end
end
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment