mirror of
https://gerrit.wikimedia.org/r/mediawiki/extensions/MultimediaViewer
synced 2024-12-19 03:11:57 +00:00
afe0397991
selenium* jobs are a new way of running Ruby based Selenium tests. The jobs are triggered daily. Bug: T128190 Change-Id: If0e6b61c9e3d52005d1851ca49ef65babd002919
175 lines
8 KiB
Ruby
175 lines
8 KiB
Ruby
# encoding: utf-8
|
|
|
|
Given /^I am at a wiki article with at least two embedded pictures$/ do
|
|
api.create_page 'MediaViewerE2ETest', File.read(File.join(__dir__, '../../samples/MediaViewerE2ETest.wikitext'))
|
|
visit(E2ETestPage)
|
|
on(E2ETestPage).image1_in_article_element.when_present.should be_visible
|
|
end
|
|
|
|
Given /^the MMV has loaded$/ do
|
|
on(E2ETestPage) do |page|
|
|
page.wait_until do
|
|
# Wait for JS to hijack standard link
|
|
# TODO: If this approach works well, we should implement general
|
|
# `wait_for_resource` and `resource_ready?` helper methods in
|
|
# mw-selenium, and document this pattern on mw.org
|
|
browser.execute_script("return mw.loader.getState('mmv.bootstrap') === 'ready'")
|
|
end
|
|
end
|
|
end
|
|
|
|
Given /^I am viewing an image using MMV$/ do
|
|
step 'I am at a wiki article with at least two embedded pictures'
|
|
step 'the MMV has loaded'
|
|
step 'I click on the second image in the article'
|
|
step 'the image metadata and the image itself should be there'
|
|
end
|
|
|
|
When /^I click on the first image in the article$/ do
|
|
on(E2ETestPage) do |page|
|
|
# We store the offset of the image as the scroll position and scroll to it, because cucumber/selenium
|
|
# sometimes automatically scrolls to it when we ask it to click on it (seems to depend on timing)
|
|
@article_scroll_top = page.execute_script("var scrollTop = Math.round($('a[href$=\"File:Sunrise_over_fishing_boats_in_Kerala.jpg\"]').first().find('img').offset().top); window.scrollTo(0, scrollTop); return scrollTop;")
|
|
# Scrolls to the image and clicks on it
|
|
page.image1_in_article
|
|
# This is a global variable that can be used to measure performance
|
|
@image_click_time = Time.now.getutc
|
|
end
|
|
end
|
|
|
|
When /^I click on the second image in the article$/ do
|
|
on(E2ETestPage) do |page|
|
|
# We store the offset of the image as the scroll position and scroll to it, because cucumber/selenium
|
|
# sometimes automatically scrolls to it when we ask it to click on it (seems to depend on timing)
|
|
@article_scroll_top = page.execute_script("var scrollTop = Math.round($('a[href$=\"File:Wikimedia_Foundation_2013_All_Hands_Offsite_-_Day_2_-_Photo_24.jpg\"]').first().find('img').offset().top); window.scrollTo(0, scrollTop); return scrollTop;")
|
|
# Scrolls to the image and clicks on it
|
|
page.image2_in_article
|
|
# This is a global variable that can be used to measure performance
|
|
@image_click_time = Time.now.getutc
|
|
end
|
|
end
|
|
|
|
When /^I close MMV$/ do
|
|
on(E2ETestPage).mmv_close_button_element.when_present(30).click
|
|
end
|
|
|
|
When /^I click the image$/ do
|
|
on(E2ETestPage) do
|
|
# Clicking the top-left corner of the image is necessary for the test to work on IE
|
|
# A plain click on the image element ends up hitting the dialog, which means it won't close
|
|
begin
|
|
browser.driver.action.move_to(browser.driver.find_element(:class, 'mw-mmv-image'), 10, 10).click.perform
|
|
rescue
|
|
# Plain click for web drivers that don't support mouse moves (Safari, currently)
|
|
on(E2ETestPage).mmv_image_div_element.when_present.click
|
|
end
|
|
end
|
|
end
|
|
|
|
Then /^the image metadata and the image itself should be there$/ do
|
|
on(E2ETestPage) do |page|
|
|
# MMV was launched, article is not visible now
|
|
page.image1_in_article_element.should_not be_visible
|
|
check_elements_in_viewer_for_image2 page
|
|
end
|
|
end
|
|
|
|
# Helper function that verifies the presence of various elements in viewer
|
|
# while looking at image1 (Kerala)
|
|
def check_elements_in_viewer_for_image1(page)
|
|
# Check basic MMV elements are present
|
|
expect(page.mmv_overlay_element.when_present).to be_visible
|
|
expect(page.mmv_wrapper_element.when_present).to be_visible
|
|
expect(page.mmv_image_div_element).to be_visible
|
|
|
|
# Check image content
|
|
expect(page.mmv_final_image_element.when_present.attribute('src')).to match /Kerala/
|
|
|
|
# Check basic metadata is present
|
|
|
|
# Title
|
|
expect(page.mmv_metadata_title_element.when_present.text).to match /^Sunrise over fishing boats$/
|
|
# License
|
|
expect(page.mmv_metadata_license_element.when_present.attribute('href')).to match %r{^http://creativecommons.org/licenses/by-sa/3.0$}
|
|
expect(page.mmv_metadata_license_element.when_present.text).to match 'CC BY-SA 3.0'
|
|
# Credit
|
|
expect(page.mmv_metadata_credit_element.when_present).to be_visible
|
|
expect(page.mmv_metadata_source_element.when_present.text).to match 'Own work'
|
|
|
|
# Image metadata
|
|
expect(page.mmv_image_metadata_wrapper_element.when_present).to be_visible
|
|
# Description
|
|
expect(page.mmv_image_metadata_desc_element.when_present.text).to match 'Sunrise over fishing boats on the beach south of Kovalam'
|
|
# Image metadata links
|
|
expect(page.mmv_image_metadata_links_wrapper_element.when_present).to be_visible
|
|
# Details link
|
|
expect(page.mmv_details_page_link_element.when_present.text).to match 'More details'
|
|
expect(page.mmv_details_page_link_element.when_present.attribute('href')).to match /boats_in_Kerala.jpg$/
|
|
end
|
|
|
|
# Helper function that verifies the presence of various elements in viewer
|
|
# while looking at image2 (Aquarium)
|
|
def check_elements_in_viewer_for_image2(page)
|
|
# Check basic MMV elements are present
|
|
expect(page.mmv_overlay_element.when_present).to be_visible
|
|
expect(page.mmv_wrapper_element.when_present).to be_visible
|
|
expect(page.mmv_image_div_element).to be_visible
|
|
|
|
# Check image content
|
|
expect(page.mmv_final_image_element.when_present(30).attribute('src')).to match 'Offsite'
|
|
|
|
# Check basic metadata is present
|
|
|
|
# Title
|
|
expect(page.mmv_metadata_title_element.when_present.text).to match /^Tropical Fish Aquarium$/
|
|
# License
|
|
expect(page.mmv_metadata_license_element.when_present(10).attribute('href')).to match %r{^http://creativecommons.org/licenses/by-sa/3.0$}
|
|
expect(page.mmv_metadata_license_element.when_present.text).to match 'CC BY-SA 3.0'
|
|
# Credit
|
|
expect(page.mmv_metadata_credit_element.when_present).to be_visible
|
|
expect(page.mmv_metadata_source_element.when_present.text).to match 'Wikimedia Foundation'
|
|
|
|
# Image metadata
|
|
expect(page.mmv_image_metadata_wrapper_element.when_present).to be_visible
|
|
# Description
|
|
expect(page.mmv_image_metadata_desc_element.when_present.text).to match 'Photo from Wikimedia Foundation'
|
|
# Image metadata links
|
|
expect(page.mmv_image_metadata_links_wrapper_element.when_present).to be_visible
|
|
# Details link
|
|
expect(page.mmv_details_page_link_element.when_present.text).to match 'More details'
|
|
expect(page.mmv_details_page_link_element.when_present.attribute('href')).to match /All_Hands_Offsite.*\.jpg$/
|
|
end
|
|
|
|
# Helper function that verifies the presence of various elements in viewer
|
|
# while looking at image3 (Hong Kong)
|
|
def check_elements_in_viewer_for_image3(page)
|
|
# Check basic MMV elements are present
|
|
expect(page.mmv_overlay_element.when_present).to be_visible
|
|
expect(page.mmv_wrapper_element.when_present).to be_visible
|
|
expect(page.mmv_image_div_element).to be_visible
|
|
|
|
# Check image content
|
|
expect(page.mmv_image_div_element.image_element.attribute('src')).to match 'Hong_Kong'
|
|
|
|
# Check basic metadata is present
|
|
|
|
# Title
|
|
expect(page.mmv_metadata_title_element.when_present.text).to match /^Hong Kong Harbor at night$/
|
|
# License
|
|
expect(page.mmv_metadata_license_element.when_present.attribute('href')).to match %r{^http://creativecommons.org/licenses/by-sa/3.0$}
|
|
expect(page.mmv_metadata_license_element.when_present.text).to match 'CC BY-SA 3.0'
|
|
# Credit
|
|
expect(page.mmv_metadata_credit_element.when_present).to be_visible
|
|
expect(page.mmv_metadata_source_element.when_present.text).to match 'Wikimedia Foundation'
|
|
|
|
# Image metadata
|
|
expect(page.mmv_image_metadata_wrapper_element.when_present).to be_visible
|
|
# Description
|
|
expect(page.mmv_image_metadata_desc_element.when_present.text).to match /Photos from our product team's talks at Wikimania 2013 in Hong Kong./
|
|
# Image metadata links
|
|
expect(page.mmv_image_metadata_links_wrapper_element.when_present).to be_visible
|
|
# Details link
|
|
expect(page.mmv_details_page_link_element.when_present.text).to match 'More details'
|
|
expect(page.mmv_details_page_link_element.when_present.attribute('href')).to match /Wikimania_2013_-_Hong_Kong_-_Photo_090\.jpg$/
|
|
end
|