--- /dev/null
+# coding: utf-8
+
+require "json"
+require "selenium-webdriver"
+$: << File.expand_path('../../', __FILE__)
+require 'spec_helper'
+Dir[File.dirname(__FILE__) + '/pages/page.rb'].each {|file| require file }
+Dir[File.dirname(__FILE__) + '/pages/quick_edit.rb'].each {|file| require file }
+Dir[File.dirname(__FILE__) + '/pages/*.rb'].each {|file| require file }
+require "uri"
+require "net/http"
+include RSpec::Expectations
+
+describe "Edit on the mypage" do
+
+ before(:all) do
+ profile = Selenium::WebDriver::Firefox::Profile.new
+ @driver = Selenium::WebDriver.for :firefox, :profile => profile
+ @driver.manage.window.maximize
+ @base_url = "http://localhost:3000/"
+ @driver.manage.timeouts.implicit_wait = 10
+ @verification_errors = []
+ @default_project = "test"
+ @default_user = "admin"
+ @default_password = "dummy"
+
+ # open issues page
+ start_page = QuickEdit::Test::Pages::StartPage.new(@driver, @base_url, @default_project)
+ first_page = start_page.login @default_user, @default_password
+ issues_page = first_page.open_issues
+
+ # create issue for test
+ issue_new_page = issues_page.open_new_page()
+ issue_show_page = issue_new_page.create(:bug, 'first subject')
+
+ @my_page = issues_page.open_mypage
+ @issue_id = @my_page.issue_ids_on_page.first
+ end
+
+ before(:each) do
+ @my_page = @my_page.open_mypage
+ end
+
+ after(:each) do
+ expect(@verification_errors).to match_array []
+ end
+
+ after(:all) do
+ @driver.quit
+ end
+
+ it "subject can edit" do
+ new_value = 'dummy'
+ expect( edit(@issue_id, :subject, new_value) ).to eq new_value
+
+ new_value = 'subject: new_value'
+ expect( edit(@issue_id, :subject, new_value) ).to eq new_value
+
+ expect( edit_with_alert(@issue_id, :subject, "") ).to eq new_value
+ end
+
+ it "start_date can edit" do
+ new_value = '1900-01-01'
+ expect( edit(@issue_id, :start_date, new_value) ).to eq new_value
+
+ new_value = '1900-01-02'
+ expect( edit(@issue_id, :start_date, new_value) ).to eq new_value
+
+ invalid_value = '1900-01-0a'
+ expect( edit_with_alert(@issue_id, :start_date, invalid_value) ).to eq new_value
+
+ invalid_value = ''
+ expect( edit_with_alert(@issue_id, :start_date, invalid_value) ).to eq new_value
+ end
+
+ it "due_date can edit" do
+ new_value = '2000-01-01'
+ expect( edit(@issue_id, :due_date, new_value) ).to eq new_value
+
+ new_value = '2000-01-02'
+ expect( edit(@issue_id, :due_date, new_value) ).to eq new_value
+
+ invalid_value = '2000-01-0a'
+ expect( edit_with_alert(@issue_id, :due_date, invalid_value) ).to eq new_value
+
+ invalid_value = ''
+ expect( edit_with_alert(@issue_id, :due_date, invalid_value) ).to eq new_value
+ end
+
+ it "description can edit" do
+ new_value = 'dummy'
+ expect( edit(@issue_id, :description, new_value) ).to eq new_value
+
+ new_value = 'description: new_value'
+ expect( edit(@issue_id, :description, new_value) ).to eq new_value
+
+ invalid_value = ''
+ expect( edit_with_alert(@issue_id, :description, invalid_value) ).to eq new_value
+ end
+
+ # unsigned float field
+ it "estimated_hours can edit" do
+ new_value = '0'
+ expect( edit(@issue_id, :estimated_hours, new_value).to_f ).to eq new_value.to_f
+
+ new_value = '0.1'
+ expect( edit(@issue_id, :estimated_hours, new_value).to_f ).to eq new_value.to_f
+
+ new_value = '+0.1'
+ expect( edit(@issue_id, :estimated_hours, new_value).to_f ).to eq new_value.to_f
+
+ new_value = '0.1e2'
+ expect( edit(@issue_id, :estimated_hours, new_value).to_f ).to eq new_value.to_f
+
+ invalid_value = ''
+ expect( edit_with_alert(@issue_id, :estimated_hours, invalid_value) ).to eq new_value.to_f
+ end
+
+ #it "parent_issue_id can edit" do
+ # issue_ids = @my_page.issue_ids_on_page
+ # issue_new_page = @my_page.open_new_page()
+ # issue_show_page = issue_new_page.create(:bug, 'first subject')
+ # new_issue_id = issue_show_page.id
+ # @my_page = issue_show_page.open_issues
+
+ # new_value = @issue_id.to_s
+ # expect( edit(new_issue_id, :parent_issue_id, new_value) ).to eq new_value.to_i
+
+ # invalid_value = ''
+ # expect( edit_with_alert(new_issue_id, :parent_issue_id, invalid_value) ).to eq new_value.to_i
+
+ # new_value = @issue_id.to_s
+ # expect( edit(new_issue_id, :parent_issue_id, new_value) ).to eq new_value.to_i
+ #end
+
+ def edit(issue_id, attribute_name, new_value)
+ quick_edit = @my_page.open_context(issue_id)
+ menu_selector = quick_edit.menu_selector(attribute_name)
+ @my_page = quick_edit.update_field(issue_id, menu_selector, new_value)
+
+ attribute_name = :parent if attribute_name.to_sym == :parent_issue_id
+ field_value = get_core_field(issue_id, attribute_name)
+
+ if attribute_name == :parent
+ field_value["id"]
+ else
+ field_value
+ end
+ end
+
+ def edit_with_alert(issue_id, attribute_name, new_value)
+ quick_edit = @my_page.open_context(issue_id)
+ menu_selector = quick_edit.menu_selector(attribute_name)
+ quick_edit.update_field issue_id, menu_selector, new_value, true
+ quick_edit.alert.accept
+ quick_edit.cancel_quick_edit
+ @my_page = quick_edit.open_mypage
+
+ attribute_name = :parent if attribute_name.to_sym == :parent_issue_id
+ field_value = get_core_field(issue_id, attribute_name)
+
+ if attribute_name == :parent
+ field_value["id"]
+ else
+ field_value
+ end
+ end
+
+ def get_core_field(issue_id, attribute_name)
+ json = get_json("issues/#{issue_id}.json")
+
+ json["issue"][attribute_name.to_s]
+ end
+
+ def get_json(path)
+ uri = URI::parse "#{@base_url}#{path}"
+ res = Net::HTTP::get_response(uri)
+ JSON.parse(res.body)
+ end
+
+
+end