summaryrefslogtreecommitdiff
path: root/www/wiki/extensions/MultimediaViewer/tests/browser/features/step_definitions/mmv_steps.rb
diff options
context:
space:
mode:
Diffstat (limited to 'www/wiki/extensions/MultimediaViewer/tests/browser/features/step_definitions/mmv_steps.rb')
-rw-r--r--www/wiki/extensions/MultimediaViewer/tests/browser/features/step_definitions/mmv_steps.rb174
1 files changed, 174 insertions, 0 deletions
diff --git a/www/wiki/extensions/MultimediaViewer/tests/browser/features/step_definitions/mmv_steps.rb b/www/wiki/extensions/MultimediaViewer/tests/browser/features/step_definitions/mmv_steps.rb
new file mode 100644
index 00000000..3e4590bc
--- /dev/null
+++ b/www/wiki/extensions/MultimediaViewer/tests/browser/features/step_definitions/mmv_steps.rb
@@ -0,0 +1,174 @@
+# 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{^https?://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{^https?://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{^https?://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