OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
openproject/features/support/paths.rb

380 lines
14 KiB

#-- copyright
# OpenProject is a project management system.
# Copyright (C) 2012-2013 the OpenProject Foundation (OPF)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2013 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# See doc/COPYRIGHT.rdoc for more details.
#++
# TL;DR: YOU SHOULD DELETE THIS FILE
#
# This file is used by web_steps.rb, which you should also delete
#
# You have been warned
module NavigationHelpers
# Maps a name to a path. Used by the
#
# When /^I go to (.+)$/ do |page_name|
#
# step definition in web_steps.rb
#
def path_to(page_name)
case page_name
when /^the home\s?page$/
'/'
when /^the login page$/
'/login'
when /^the(?: "(.+?)" tab of the)? settings page (?:of|for) the project called "(.+?)"$/
tab = $1 || ""
project_identifier = $2.gsub("\"", "")
tab.gsub("\"", "")
project_identifier = Project.find_by_name(project_identifier).identifier.gsub(' ', '%20')
if tab == ""
"/projects/#{project_identifier}/settings"
else
"/projects/#{project_identifier}/settings/#{tab}"
end
when /^the [wW]iki [pP]age "([^\"]+)" (?:for|of) the project called "([^\"]+)"$/
wiki_page = Wiki.titleize($1)
project_identifier = $2.gsub("\"", "")
project = Project.find_by_name(project_identifier)
project_identifier = project.identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/wiki/#{wiki_page}"
when /^the edit menu item page of the [wW]iki [pP]age "([^\"]+)" (?:for|of) the project called "([^\"]+)"$/
wiki_page = Wiki.titleize($1)
project_identifier = $2.gsub("\"", "")
project = Project.find_by_name(project_identifier)
project_identifier = project.identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/wiki/#{wiki_page}/wiki_menu_item/edit"
when /^the [cC]ost [rR]eports page (?:of|for) the project called "([^\"]+)" without filters or groups$/
project_identifier = Project.find_by_name($1).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/cost_reports?set_filter=1"
when /^the [cC]ost [rR]eports page (?:of|for) the project called "([^\"]+)"$/
project_identifier = Project.find_by_name($1).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/cost_reports"
when /^the overall [cC]ost [rR]eports page$/
"/cost_reports"
when /^the overall [cC]ost [rR]eports page without filters or groups$/
"/cost_reports?set_filter=1"
when /^the overall [cC]ost [rR]eports page with standard groups in debug mode$/
"/cost_reports?set_filter=1&groups[columns][]=cost_type_id&groups[rows][]=user_id&debug=1"
when /^the overall [cC]ost [rR]eports page with standard groups$/
"/cost_reports?set_filter=1&groups[columns][]=cost_type_id&groups[rows][]=user_id"
when /^the overall [pP]rojects page$/
"/projects"
when /^the (?:(?:overview |home ?))?page (?:for|of) the project(?: called)? "(.+)"$/
project_identifier = $1.gsub("\"", "")
project_identifier = Project.find_by_name(project_identifier).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}"
when /^the activity page of the project(?: called)? "(.+)"$/
project_identifier = $1.gsub("\"", "")
project_identifier = Project.find_by_name(project_identifier).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/activity"
when /^the overall activity page$/
"/activity"
when /^the page (?:for|of) the issue "([^\"]+)"$/
issue = WorkPackage.find_by_subject($1)
"/work_packages/#{issue.id}"
when /^the edit page (?:for|of) the issue "([^\"]+)"$/
issue = WorkPackage.find_by_subject($1)
"/issues/#{issue.id}/edit"
when /^the copy page (?:for|of) the work package "([^\"]+)"$/
package = WorkPackage.find_by_subject($1)
project = package.project
"/projects/#{project.identifier}/work_packages/new?copy_from=#{package.id}"
when /^the work packages? index page (?:for|of) (the)? project(?: called)? (.+)$/
project_identifier = $2.gsub("\"", "")
project_identifier = Project.find_by_name(project_identifier).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/work_packages"
when /^the page (?:for|of) the work package(?: called)? "([^\"]+)"$/
work_package = WorkPackage.find_by_subject($1)
"/work_packages/#{work_package.id}"
when /^the new work_package page (?:for|of) the project called "([^\"]+)"$/
"/projects/#{$1}/work_packages/new"
when /^the bulk destroy page of work packages$/
Rails.application.routes.url_helpers.work_packages_bulk_path
when /^the wiki index page(?: below the (.+) page)? (?:for|of) (?:the)? project(?: called)? (.+)$/
parent_page_title, project_identifier = $1, $2
project_identifier.gsub!("\"", "")
project_identifier = Project.find_by_name(project_identifier).identifier.gsub(' ', '%20')
if parent_page_title.present?
parent_page_title.gsub!("\"", "")
"/projects/#{project_identifier}/wiki/#{parent_page_title}/toc"
else
"/projects/#{project_identifier}/wiki/index"
end
when /^the wiki new child page below the (.+) page (?:for|of) (?:the)? project(?: called)? (.+)$/
parent_page_title, project_identifier = $1, $2
project_identifier.gsub!("\"", "")
parent_page_title.gsub!("\"", "")
project_identifier = Project.find_by_name(project_identifier).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/wiki/#{parent_page_title}/new"
when /^the edit page (?:for |of )(the )?role(?: called)? (.+)$/
role_identifier = $2.gsub("\"", "")
role_identifier = Role.find_by_name(role_identifier).id
"/roles/edit/#{role_identifier}"
when /^the new user page$/
"/users/new"
when /^the edit page (?:for |of )(the )?user(?: called)? (.+)$/
user_identifier = $2.gsub("\"", "")
user_identifier = User.find_by_login(user_identifier).id
"/users/#{user_identifier}/edit"
when /^the (.+) tab of the edit page (?:for |of )(the )?user(?: called)? (.+)$/
tab = $1
user_identifier = $3.gsub("\"", "")
user_identifier = User.find_by_login(user_identifier).id
"/users/#{user_identifier}/edit/#{tab}"
when /^the show page (?:for |of )(the )?user(?: called)? (.+)$/
user_identifier = $2.gsub("\"", "")
user_identifier = User.find_by_login(user_identifier).id
"/users/#{user_identifier}"
when /^the index page (?:for|of) users$/
"/users"
when /^the global index page (?:for|of) (.+)$/
"/#{$1.gsub(" ", "_")}"
when /^the edit page (?:for |of )the version(?: called) (.+)$/
version_name = $1.gsub("\"", "")
version = Version.find_by_name(version_name)
"/versions/edit/#{version.id}"
# this should be handled by the generic "the edit page of ..." path
# but the path required differs from the standard
# delete once the path is corrected
when /the edit page (?:for |of )the (?:issue )?custom field(?: called) (.+)/
name = $1.gsub("\"", "")
instance = InstanceFinder.find(CustomField, name)
"/custom_fields/edit/#{instance.id}"
when /^the new page (?:for|of) (.+)$/
model = $1.gsub!("\"", "").downcase
"/#{model.pluralize}/new"
when /^the edit page of the group called "([^\"]+)"$/
identifier = $1.gsub("\"", "")
instance = InstanceFinder.find(Group, identifier)
"/admin/groups/#{instance.id}/edit"
when /^the edit page (?:for|of) (?:the )?([^\"]+?)(?: called)? "([^\"]+)"$/
model, identifier = $1, $2
identifier.gsub!("\"", "")
model = model.gsub("\"", "").gsub(/\s/, "_")
begin
instance = InstanceFinder.find(model.camelize.constantize, identifier)
rescue NameError
instance = InstanceFinder.find(model.to_sym, identifier)
end
root = RouteMap.route(instance.class)
"#{root}/#{instance.id}/edit"
when /^the log ?out page$/
'/logout'
when /^the (register|registration) page$/
'/account/register'
when /^the activate registration page for the user called (.+) with (.+)$/
name = $1.dup
selection = $2.dup
name.gsub!("\"","")
selection.gsub!("\"","")
u = User.find_by_login(name)
"/account/#{u.id}/activate?#{selection}"
when /^the My page$/
'/my/page'
when /^the My page personalization page$/
"/my/page_layout"
when /^the [mM]y account page$/
'/my/account'
when /^the (administration|admin) page$/
'/admin'
when /^the(?: (.+?) tab of the)? settings page$/
if $1.nil?
"/settings"
else
"/settings/edit?tab=#{$1}"
end
when /^the(?: (.+?) tab of the)? settings page (?:of|for) the project "(.+?)"$/
if $1.nil?
"/projects/#{$2}/settings"
else
"/projects/#{$2}/settings/#{$1}"
end
when /^the edit page of Announcement$/
'/announcements/1/edit'
when /^the index page of Roles$/
'/roles'
when /^the search page$/
'/search'
when /^the custom fields page$/
'/custom_fields'
when /^the enumerations page$/
'/admin/enumerations'
when /^the projects admin page$/
'/admin/projects'
when /^the authentication modes page$/
'/admin/auth_sources'
when /the page of the timeline(?: "([^\"]+)")? of the project called "([^\"]+)"$/
timeline_name = $1
project_name = $2
project = Project.find_by_name(project_name)
project_identifier = project.identifier.gsub(' ', '%20')
timeline = project.timelines.detect { |t| t.name == timeline_name }
timeline_id = timeline ?
"/#{timeline.id}" :
""
"/projects/#{project_identifier}/timelines#{timeline_id}"
when /the new timeline page of the project called "([^\"]+)"$/
project_name = $1
project_identifier = Project.find_by_name(project_name).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/timelines/new"
when /the edit page of the timeline "([^\"]+)" of the project called "([^\"]+)"$/
timeline_name = $1
project_name = $2
project_identifier = Project.find_by_name(project_name).identifier.gsub(' ', '%20')
timeline = Timeline.find_by_name(timeline_name)
"/projects/#{project_identifier}/timelines/#{timeline.id}/edit"
when /^the page of the planning element "([^\"]+)" of the project called "([^\"]+)"$/
planning_element_name = $1
planning_element = WorkPackage.find_by_subject(planning_element_name)
"/work_packages/#{planning_element.id}"
when /^the (.+) page (?:for|of) the project called "([^\"]+)"$/
project_page = $1
project_identifier = $2.gsub("\"", "")
project_page = project_page.gsub(' ', '').underscore
project_identifier = Project.find_by_name(project_identifier).identifier.gsub(' ', '%20')
"/projects/#{project_identifier}/#{project_page}"
when /^the quick reference for wiki syntax$/
"/help/wiki_syntax"
when /^the detailed wiki syntax help page$/
"/help/wiki_syntax_detailed"
when /^the configuration page of the "(.+)" plugin$/
"/settings/plugin/#{$1}"
when /^the admin page of the group called "([^"]*)"$/
id = Group.find_by_lastname!($1).id
"/admin/groups/#{id}/edit"
when /^the time entry page of issue "(.+)"$/
issue_id = WorkPackage.find_by_subject($1).id
"/work_packages/#{issue_id}/time_entries"
when /^the move new page of the work package "(.+)"$/
work_package_id = WorkPackage.find_by_subject($1).id
"/work_packages/#{work_package_id}/move/new?copy="
when /^the applied query "([^\"]+)" on the work packages index page of the project "([^\"]+)"$/
project = Project.find_by_name($2)
query = project.queries.find_by_name($1)
project_work_packages_path project, query_id: query.id
when /^the move page of the work package "(.+)"$/
work_package_id = WorkPackage.find_by_subject($1).id
"/work_packages/#{work_package_id}/move/new"
when /^the message page of message "(.+)"$/
message = Message.find_by_subject($1)
topic_path(message)
# Add more mappings here.
# Here is an example that pulls values out of the Regexp:
#
# when /^(.*)'s profile page$/i
# user_profile_path(User.find_by_login($1))
else
begin
page_name =~ /^the (.*) page$/
path_components = $1.split(/\s+/)
self.send(path_components.push('path').join('_').to_sym)
rescue NoMethodError, ArgumentError
raise "Can't find mapping from \"#{page_name}\" to a path.\n" +
"Now, go and add a mapping in #{__FILE__}"
end
end
end
end
World(NavigationHelpers)