Commit 1479f1722702c955ed3ee9456107c6a1a7277c7b
1 parent
ea9b3687
Exists in
master
and in
4 other branches
Add Spinach coverage for Gollum Wiki system and correct the Delete link.
The previously failing Spinach steps have been fixed with this commit. I have also added new steps that cover the entire usage of the Wiki system. The new Spinach steps revealed a minor bug in the Delete page process. The path for the "Delete this page" button was previously set to `project_wikis_page(@project, @wiki)` when it should have been using the singular `project_wiki_page(@project, @wiki)` path helper. The link has been corrected and all steps are now passing.
Showing
5 changed files
with
102 additions
and
10 deletions
Show diff stats
app/views/wikis/edit.html.haml
| ... | ... | @@ -5,6 +5,6 @@ |
| 5 | 5 | = render 'form' |
| 6 | 6 | |
| 7 | 7 | .pull-right |
| 8 | - - if can? current_user, :admin_wiki, @project | |
| 9 | - = link_to project_wikis_path(@project, @wiki), confirm: "Are you sure you want to delete this page?", method: :delete, class: "btn btn-small btn-remove" do | |
| 8 | + - if @wiki.persisted? && can?(current_user, :admin_wiki, @project) | |
| 9 | + = link_to project_wiki_path(@project, @wiki), confirm: "Are you sure you want to delete this page?", method: :delete, class: "btn btn-small btn-remove" do | |
| 10 | 10 | Delete this page | ... | ... |
features/project/wiki.feature
| ... | ... | @@ -5,5 +5,32 @@ Feature: Project Wiki |
| 5 | 5 | Given I visit project wiki page |
| 6 | 6 | |
| 7 | 7 | Scenario: Add new page |
| 8 | - Given I create Wiki page | |
| 9 | - Then I should see newly created wiki page | |
| 8 | + Given I create the Wiki Home page | |
| 9 | + Then I should see the newly created wiki page | |
| 10 | + | |
| 11 | + Scenario: Edit existing page | |
| 12 | + Given I have an existing Wiki page | |
| 13 | + And I browse to that Wiki page | |
| 14 | + And I click on the Edit button | |
| 15 | + And I change the content | |
| 16 | + Then I should see the updated content | |
| 17 | + | |
| 18 | + Scenario: View page history | |
| 19 | + Given I have an existing wiki page | |
| 20 | + And That page has two revisions | |
| 21 | + And I browse to that Wiki page | |
| 22 | + And I click the History button | |
| 23 | + Then I should see both revisions | |
| 24 | + | |
| 25 | + Scenario: Destroy Wiki page | |
| 26 | + Given I have an existing wiki page | |
| 27 | + And I browse to that Wiki page | |
| 28 | + And I click on the Edit button | |
| 29 | + And I click on the "Delete this page" button | |
| 30 | + Then The page should be deleted | |
| 31 | + | |
| 32 | + Scenario: View all pages | |
| 33 | + Given I have an existing wiki page | |
| 34 | + And I browse to that Wiki page | |
| 35 | + And I click on the "Pages" button | |
| 36 | + Then I should see the existing page in the pages list | ... | ... |
features/steps/project/project_wiki.rb
| ... | ... | @@ -4,17 +4,73 @@ class ProjectWiki < Spinach::FeatureSteps |
| 4 | 4 | include SharedNote |
| 5 | 5 | include SharedPaths |
| 6 | 6 | |
| 7 | - Given 'I create Wiki page' do | |
| 8 | - fill_in "Title", :with => 'Test title' | |
| 7 | + Given 'I create the Wiki Home page' do | |
| 9 | 8 | fill_in "Content", :with => '[link test](test)' |
| 10 | 9 | click_on "Save" |
| 11 | 10 | end |
| 12 | 11 | |
| 13 | - Then 'I should see newly created wiki page' do | |
| 14 | - page.should have_content "Test title" | |
| 12 | + Then 'I should see the newly created wiki page' do | |
| 13 | + page.should have_content "Home" | |
| 15 | 14 | page.should have_content "link test" |
| 16 | 15 | |
| 17 | 16 | click_link "link test" |
| 18 | 17 | page.should have_content "Editing page" |
| 19 | 18 | end |
| 19 | + | |
| 20 | + Given 'I have an existing Wiki page' do | |
| 21 | + wiki.create_page("existing", "content", :markdown, "first commit") | |
| 22 | + @page = wiki.find_page("existing") | |
| 23 | + end | |
| 24 | + | |
| 25 | + And 'I browse to that Wiki page' do | |
| 26 | + visit project_wiki_path(project, @page) | |
| 27 | + end | |
| 28 | + | |
| 29 | + And 'I click on the Edit button' do | |
| 30 | + click_on "Edit" | |
| 31 | + end | |
| 32 | + | |
| 33 | + And 'I change the content' do | |
| 34 | + fill_in "Content", :with => 'Updated Wiki Content' | |
| 35 | + click_on "Save" | |
| 36 | + end | |
| 37 | + | |
| 38 | + Then 'I should see the updated content' do | |
| 39 | + page.should have_content "Updated Wiki Content" | |
| 40 | + end | |
| 41 | + | |
| 42 | + And 'That page has two revisions' do | |
| 43 | + @page.update("new content", :markdown, "second commit") | |
| 44 | + end | |
| 45 | + | |
| 46 | + And 'I click the History button' do | |
| 47 | + click_on "History" | |
| 48 | + end | |
| 49 | + | |
| 50 | + Then 'I should see both revisions' do | |
| 51 | + page.should have_content current_user.name | |
| 52 | + page.should have_content "first commit" | |
| 53 | + page.should have_content "second commit" | |
| 54 | + end | |
| 55 | + | |
| 56 | + And 'I click on the "Delete this page" button' do | |
| 57 | + click_on "Delete this page" | |
| 58 | + end | |
| 59 | + | |
| 60 | + Then 'The page should be deleted' do | |
| 61 | + page.should have_content "Page was successfully deleted" | |
| 62 | + end | |
| 63 | + | |
| 64 | + And 'I click on the "Pages" button' do | |
| 65 | + click_on "Pages" | |
| 66 | + end | |
| 67 | + | |
| 68 | + Then 'I should see the existing page in the pages list' do | |
| 69 | + page.should have_content current_user.name | |
| 70 | + page.should have_content @page.title.titleize | |
| 71 | + end | |
| 72 | + | |
| 73 | + def wiki | |
| 74 | + @gollum_wiki = GollumWiki.new(project, current_user) | |
| 75 | + end | |
| 20 | 76 | end | ... | ... |
features/steps/shared/paths.rb
| ... | ... | @@ -161,7 +161,7 @@ module SharedPaths |
| 161 | 161 | end |
| 162 | 162 | |
| 163 | 163 | Given "I visit my project's wiki page" do |
| 164 | - visit project_wiki_path(@project, :index) | |
| 164 | + visit project_wiki_path(@project, :home) | |
| 165 | 165 | end |
| 166 | 166 | |
| 167 | 167 | When 'I visit project hooks page' do |
| ... | ... | @@ -256,7 +256,7 @@ module SharedPaths |
| 256 | 256 | end |
| 257 | 257 | |
| 258 | 258 | Given 'I visit project wiki page' do |
| 259 | - visit project_wiki_path(@project, :index) | |
| 259 | + visit project_wiki_path(@project, :home) | |
| 260 | 260 | end |
| 261 | 261 | |
| 262 | 262 | def root_ref | ... | ... |
features/support/env.rb
| ... | ... | @@ -32,6 +32,9 @@ DatabaseCleaner.strategy = :truncation |
| 32 | 32 | Spinach.hooks.before_scenario do |
| 33 | 33 | # Use tmp dir for FS manipulations |
| 34 | 34 | Gitlab.config.gitlab_shell.stub(repos_path: Rails.root.join('tmp', 'test-git-base-path')) |
| 35 | + Gitlab::Shell.any_instance.stub(:add_repository) do |path| | |
| 36 | + create_temp_repo("#{Rails.root}/tmp/test-git-base-path/#{path}.git") | |
| 37 | + end | |
| 35 | 38 | FileUtils.rm_rf Gitlab.config.gitlab_shell.repos_path |
| 36 | 39 | FileUtils.mkdir_p Gitlab.config.gitlab_shell.repos_path |
| 37 | 40 | DatabaseCleaner.start |
| ... | ... | @@ -46,3 +49,9 @@ Spinach.hooks.before_run do |
| 46 | 49 | |
| 47 | 50 | include FactoryGirl::Syntax::Methods |
| 48 | 51 | end |
| 52 | + | |
| 53 | +def create_temp_repo(path) | |
| 54 | + FileUtils.mkdir_p path | |
| 55 | + command = "git init --quiet --bare #{path};" | |
| 56 | + system(command) | |
| 57 | +end | ... | ... |