Commit 5e08e4ec9fc26b13464df0095df6f13596393fe1
Committed by
Rafael Manzo
1 parent
71e31d89
Exists in
colab
and in
4 other branches
Helpers reading group
Missing Acceptance Test Signed-off By : Guilherme Rojas V. de Lima <guilhermehrojas@gmail.com>
Showing
5 changed files
with
93 additions
and
1 deletions
Show diff stats
app/controllers/readings_controller.rb
app/views/reading_groups/index.html.erb
| ... | ... | @@ -0,0 +1,16 @@ |
| 1 | +<div class="page-header"> | |
| 2 | + <h1>Reading Groups</h1> | |
| 3 | +</div> | |
| 4 | + | |
| 5 | +<% if user_signed_in? %> | |
| 6 | + <p> | |
| 7 | + <%= link_to 'New Reading Group', new_reading_group_path, class: 'btn btn-primary' %> | |
| 8 | + </p> | |
| 9 | +<%else%> | |
| 10 | + <p class="alert alert-warning alert-dismissable"> | |
| 11 | + <button type="button" class="close" data-dismiss="alert" aria-hidden="true">×</button> | |
| 12 | + To create new reading groups you must be logged in page. | |
| 13 | + </p> | |
| 14 | +<% end %> | |
| 15 | + | |
| 16 | +<%= render partial: 'shared/reading_groups_list', locals: {reading_groups: @reading_groups} %> | |
| 0 | 17 | \ No newline at end of file | ... | ... |
| ... | ... | @@ -0,0 +1,25 @@ |
| 1 | +<table class="table table-hover"> | |
| 2 | + <thead> | |
| 3 | + <tr> | |
| 4 | + <th>Name</th> | |
| 5 | + <th>Description</th> | |
| 6 | + <th colspan="2"></th> | |
| 7 | + </tr> | |
| 8 | + </thead> | |
| 9 | + | |
| 10 | + <tbody> | |
| 11 | + <% reading_groups.each do |reading_group| %> | |
| 12 | + <% p reading_group %> | |
| 13 | + <tr> | |
| 14 | + <td><%= reading_group.name %></td> | |
| 15 | + <td><%= reading_group.description %></td> | |
| 16 | + <td><%= link_to 'Show', reading_group_path(reading_group.id), class: 'btn btn-info' %></td> | |
| 17 | + <td> | |
| 18 | + <% if reading_groups_owner? reading_group.id %> | |
| 19 | + <%= link_to 'Edit', edit_reading_group_path(reading_group.id), class: 'btn btn-info' %> | |
| 20 | + <% end %> | |
| 21 | + </td> | |
| 22 | + </tr> | |
| 23 | + <% end %> | |
| 24 | + </tbody> | |
| 25 | +</table> | |
| 0 | 26 | \ No newline at end of file | ... | ... |
| ... | ... | @@ -0,0 +1,46 @@ |
| 1 | +require 'spec_helper' | |
| 2 | + | |
| 3 | +describe ReadingGroupsHelper do | |
| 4 | + | |
| 5 | + describe 'reading_group_owner?' do | |
| 6 | + before :each do | |
| 7 | + @subject = FactoryGirl.build(:reading_group) | |
| 8 | + end | |
| 9 | + | |
| 10 | + context 'returns false if not logged in' do | |
| 11 | + before :each do | |
| 12 | + helper.expects(:user_signed_in?).returns(false) | |
| 13 | + end | |
| 14 | + it { helper.reading_groups_owner?(@subject.id).should be_false } | |
| 15 | + end | |
| 16 | + | |
| 17 | + context 'returns false if is not the owner' do | |
| 18 | + before :each do | |
| 19 | + helper.expects(:user_signed_in?).returns(true) | |
| 20 | + helper.expects(:current_user).returns(FactoryGirl.build(:user)) | |
| 21 | + | |
| 22 | + @ownerships = [] | |
| 23 | + @ownerships.expects(:find_by_reading_group_id).with(@subject.id).returns(nil) | |
| 24 | + | |
| 25 | + User.any_instance.expects(:reading_group_ownerships).returns(@ownerships) | |
| 26 | + end | |
| 27 | + | |
| 28 | + it { helper.reading_groups_owner?(@subject.id).should be_false } | |
| 29 | + end | |
| 30 | + | |
| 31 | + context 'returns true if user is the reading_group owner' do | |
| 32 | + before :each do | |
| 33 | + helper.expects(:user_signed_in?).returns(true) | |
| 34 | + helper.expects(:current_user).returns(FactoryGirl.build(:user)) | |
| 35 | + | |
| 36 | + @ownership = FactoryGirl.build(:reading_group_ownership) | |
| 37 | + @ownerships = [] | |
| 38 | + @ownerships.expects(:find_by_reading_group_id).with(@subject.id).returns(@ownership) | |
| 39 | + User.any_instance.expects(:reading_group_ownerships).returns(@ownerships) | |
| 40 | + end | |
| 41 | + | |
| 42 | + it { helper.reading_groups_owner?(@subject.id).should be_true } | |
| 43 | + end | |
| 44 | + end | |
| 45 | + | |
| 46 | +end | |
| 0 | 47 | \ No newline at end of file | ... | ... |