mirror of
https://github.com/TracksApp/tracks.git
synced 2025-12-16 15:20:13 +01:00
135 lines
5.2 KiB
Ruby
135 lines
5.2 KiB
Ruby
When /^I delete project "([^"]*)"$/ do |project_name|
|
|
project = @current_user.projects.where(:name => project_name).first
|
|
expect(project).to_not be_nil
|
|
|
|
handle_js_confirm do
|
|
click_link "delete_project_#{project.id}"
|
|
end
|
|
expect(get_confirm_text).to eq("Are you sure that you want to delete the project '#{project_name}'?")
|
|
|
|
expect(page).to_not have_css("a#delete_project_#{project.id}")
|
|
end
|
|
|
|
When /^I drag the project "([^"]*)" below "([^"]*)"$/ do |project_drag, project_drop|
|
|
drag_id = @current_user.projects.where(:name => project_drag).first.id
|
|
sortable_css = "div.ui-sortable div#container_project_#{drag_id}"
|
|
|
|
drag_index = project_list_find_index(project_drag)
|
|
drop_index = project_list_find_index(project_drop)
|
|
|
|
page.execute_script "$('#{sortable_css}').simulateDragSortable({move: #{drop_index-drag_index}, handle: '.grip'});"
|
|
sleep 0.1 # wait for the js to process the drop
|
|
end
|
|
|
|
When /^I submit a new project with name "([^"]*)"$/ do |project_name|
|
|
fill_in "project[name]", :with => project_name
|
|
submit_new_project_form
|
|
end
|
|
|
|
When /^I submit a new project with name "([^"]*)" and select take me to the project$/ do |project_name|
|
|
fill_in "project[name]", :with => project_name
|
|
check "go_to_project"
|
|
submit_new_project_form
|
|
end
|
|
|
|
When /^I sort the active list alphabetically$/ do
|
|
handle_js_confirm do
|
|
within "div#list-active-projects-container" do
|
|
click_link "Alphabetically"
|
|
end
|
|
wait_for_ajax
|
|
end
|
|
expect(get_confirm_text).to eq("Are you sure that you want to sort these projects alphabetically? This will replace the existing sort order.")
|
|
end
|
|
|
|
When /^I sort the active list by number of tasks$/ do
|
|
handle_js_confirm do
|
|
within "div#list-active-projects-container" do
|
|
click_link "By number of tasks"
|
|
end
|
|
wait_for_ajax
|
|
end
|
|
expect(get_confirm_text).to eq("Are you sure that you want to sort these projects by the number of tasks? This will replace the existing sort order.")
|
|
end
|
|
|
|
Then /^I should see that a project named "([^"]*)" is not present$/ do |project_name|
|
|
within "div#display_box" do
|
|
step "I should not see \"#{project_name}\""
|
|
end
|
|
end
|
|
|
|
Then /^I should see that a project named "([^"]*)" is present$/ do |project_name|
|
|
within "div#display_box" do
|
|
step "I should see \"#{project_name}\""
|
|
end
|
|
end
|
|
|
|
Then /^I should see a project named "([^"]*)"$/ do |project_name|
|
|
step "I should see that a project named \"#{project_name}\" is present"
|
|
end
|
|
|
|
Then /^I should not see a project named "([^"]*)"$/ do |project_name|
|
|
step "I should see that a project named \"#{project_name}\" is not present"
|
|
end
|
|
|
|
Then(/^I should not see the project "(.*?)"$/) do |project_name|
|
|
project = @current_user.projects.where(:name => project_name).first
|
|
expect(project).to_not be_nil
|
|
|
|
project_xpath = "//div[@id='project_#{project.id}']"
|
|
expect(page).to_not have_xpath(project_xpath)
|
|
end
|
|
|
|
Then /^the project "([^"]*)" should be above the project "([^"]*)"$/ do |project_high, project_low|
|
|
expect(project_list_find_index(project_high)).to be < project_list_find_index(project_low)
|
|
end
|
|
|
|
Then /^the project "([^"]*)" should not be in state list "([^"]*)"$/ do |project_name, state_name|
|
|
project = @current_user.projects.where(:name => project_name).first
|
|
expect(project).to_not be_nil
|
|
|
|
list_id = @source_view=="review" ? "list-#{state}-projects" : "list-#{state_name}-projects-container"
|
|
xpath = "//div[@id='#{list_id}']//div[@id='project_#{project.id}']"
|
|
|
|
expect(page).to_not have_xpath(xpath)
|
|
end
|
|
|
|
Then /^the project "([^"]*)" should be in state list "([^"]*)"$/ do |project_name, state_name|
|
|
project = @current_user.projects.where(:name => project_name).first
|
|
expect(project).to_not be_nil
|
|
|
|
list_id = @source_view=="review" ? "list-#{state_name}-projects" : "list-#{state_name}-projects-container"
|
|
xpath = "//div[@id='#{list_id}']//div[@id='project_#{project.id}']"
|
|
|
|
expect(page).to have_xpath(xpath)
|
|
end
|
|
|
|
Then /^I see the project "([^"]*)" in the "([^"]*)" list$/ do |project_name, state_name|
|
|
step "the project \"#{project_name}\" should be in state list \"#{state_name}\""
|
|
end
|
|
|
|
Then /^the project list badge for "([^"]*)" projects should show (\d+)$/ do |state_name, count|
|
|
expect(page.find(:xpath, "//span[@id='#{state_name}-projects-count']").text).to eq(count)
|
|
end
|
|
|
|
Then /^the new project form should be visible$/ do
|
|
expect(page).to have_css("div#project_new", :visible => true)
|
|
end
|
|
|
|
Then /^the new project form should not be visible$/ do
|
|
expect(page).to_not have_css("div#project_new", :visible => true)
|
|
end
|
|
|
|
Then /^the project "([^"]*)" should have (\d+) actions listed$/ do |project_name, count|
|
|
project = @current_user.projects.where(:name => project_name).first
|
|
expect(project).to_not be_nil
|
|
xpath = "//div[@id='list-active-projects-container']//div[@id='project_#{project.id}']"
|
|
expect(page.find(:xpath, xpath).text).to eq("#{project.name} (#{count} actions)")
|
|
end
|
|
|
|
Then /^the project "([^"]*)" should have (\d+) deferred actions listed$/ do |project_name, deferred|
|
|
project = @current_user.projects.where(:name => project_name).first
|
|
expect(project).to_not be_nil
|
|
xpath = "//div[@id='list-active-projects-container']//div[@id='project_#{project.id}']"
|
|
expect(page.find(:xpath, xpath).text).to eq("#{project.name} (#{deferred} deferred actions)")
|
|
end
|