4 require "selenium-webdriver"
5 $: << File.expand_path('../../', __FILE__)
7 Dir[File.dirname(__FILE__) + '/pages/page.rb'].each {|file| require file }
8 Dir[File.dirname(__FILE__) + '/pages/*.rb'].each {|file| require file }
11 include RSpec::Expectations
13 describe "Replace core field" do
16 profile = Selenium::WebDriver::Firefox::Profile.new
17 @driver = Selenium::WebDriver.for :firefox, :profile => profile
18 @driver.manage.window.maximize
19 @base_url = "http://localhost:3000/"
20 @driver.manage.timeouts.implicit_wait = 10
21 @verification_errors = []
22 @default_project = "test"
23 @default_user = "admin"
24 @default_password = "dummy"
27 start_page = QuickEdit::Test::Pages::StartPage.new(@driver, @base_url, @default_project)
28 first_page = start_page.login @default_user, @default_password
29 @issues_page = first_page.open_issues
31 # create issue for test
32 issue_new_page = @issues_page.open_new_page()
33 issue_show_page = issue_new_page.create(:bug, 'initial text')
34 @issue_id = issue_show_page.id
39 @issues_page = @issues_page.open_issues
43 expect(@verification_errors).to match_array []
50 it "subject can replace" do
51 new_value = 'NEW text'
55 expect( replace(@issue_id, :subject, find, replace, match_case) ).to eq new_value
57 # match case test: to lower
58 new_value = 'new text'
62 expect( replace(@issue_id, :subject, find, replace, match_case) ).to eq new_value
65 new_value = "new<>\'\"&\\+ %text"
67 replace = "<>\'\"&\\+ %"
69 expect( replace(@issue_id, :subject, find, replace, match_case) ).to eq new_value
71 # escape test for meta character of regexp pattern
72 new_value = "new<>\'\"&\\++ %text"
76 expect( replace(@issue_id, :subject, find, replace, match_case) ).to eq new_value
81 expect( replace_with_alert(@issue_id, :subject, find, replace, match_case) ).to eq new_value
84 def edit(issue_id, attribute_name, new_value)
85 quick_edit = @issues_page.open_context(issue_id)
86 menu_selector = quick_edit.menu_selector(attribute_name)
87 @issues_page = quick_edit.update_field(issue_id, menu_selector, new_value)
89 attribute_name = :parent if attribute_name.to_sym == :parent_issue_id
90 field_value = get_core_field(issue_id, attribute_name)
92 if attribute_name == :parent
99 def replace(issue_id, attribute_name, find, replace, match_case)
100 quick_edit = @issues_page.open_context(issue_id)
101 menu_selector = quick_edit.menu_selector(attribute_name)
102 @issues_page = quick_edit.replace(issue_id, menu_selector, find, replace, match_case)
104 attribute_name = :parent if attribute_name.to_sym == :parent_issue_id
105 field_value = get_core_field(issue_id, attribute_name)
107 if attribute_name == :parent
114 def replace_with_alert(issue_id, attribute_name, find, replace, match_case)
115 quick_edit = @issues_page.open_context(issue_id)
116 menu_selector = quick_edit.menu_selector(attribute_name)
117 quick_edit.replace(issue_id, menu_selector, find, replace, match_case, true)
118 quick_edit.alert.accept
119 quick_edit.cancel_quick_edit
121 attribute_name = :parent if attribute_name.to_sym == :parent_issue_id
122 field_value = get_core_field(issue_id, attribute_name)
124 if attribute_name == :parent
131 def get_core_field(issue_id, attribute_name)
132 json = get_json("issues/#{issue_id}.json")
134 json["issue"][attribute_name.to_s]
138 uri = URI::parse "#{@base_url}#{path}"
139 res = Net::HTTP::get_response(uri)