From 48a8223ecfdfbbbcd87309c48a441e9a047c555f Mon Sep 17 00:00:00 2001 From: Bryan Larsen Date: Mon, 3 Jun 2013 16:38:24 +0200 Subject: [PATCH] generate-story-status-model ## Have a configurable set of statuses In order to support management of the statuses available, we'll create a StoryStatus model $ hobo generate resource story_status name:string --- app/controllers/story_statuses_controller.rb | 7 +++++ app/models/story_status.rb | 29 +++++++++++++++++++ test/fixtures/story_statuses.yml | 11 +++++++ .../story_statuses_controller_test.rb | 7 +++++ test/unit/story_status_test.rb | 7 +++++ 5 files changed, 61 insertions(+) create mode 100644 app/controllers/story_statuses_controller.rb create mode 100644 app/models/story_status.rb create mode 100644 test/fixtures/story_statuses.yml create mode 100644 test/functional/story_statuses_controller_test.rb create mode 100644 test/unit/story_status_test.rb diff --git a/app/controllers/story_statuses_controller.rb b/app/controllers/story_statuses_controller.rb new file mode 100644 index 0000000..53a3817 --- /dev/null +++ b/app/controllers/story_statuses_controller.rb @@ -0,0 +1,7 @@ +class StoryStatusesController < ApplicationController + + hobo_model_controller + + auto_actions :all + +end diff --git a/app/models/story_status.rb b/app/models/story_status.rb new file mode 100644 index 0000000..83ba26b --- /dev/null +++ b/app/models/story_status.rb @@ -0,0 +1,29 @@ +class StoryStatus < ActiveRecord::Base + + hobo_model # Don't put anything above this + + fields do + name :string + timestamps + end + attr_accessible :name + + # --- Permissions --- # + + def create_permitted? + acting_user.administrator? + end + + def update_permitted? + acting_user.administrator? + end + + def destroy_permitted? + acting_user.administrator? + end + + def view_permitted?(field) + true + end + +end diff --git a/test/fixtures/story_statuses.yml b/test/fixtures/story_statuses.yml new file mode 100644 index 0000000..c63aac0 --- /dev/null +++ b/test/fixtures/story_statuses.yml @@ -0,0 +1,11 @@ +# Read about fixtures at http://api.rubyonrails.org/classes/ActiveRecord/Fixtures.html + +# This model initially had no columns defined. If you add columns to the +# model remove the '{}' from the fixture names and add the columns immediately +# below each fixture, per the syntax in the comments below +# +one: {} +# column: value +# +two: {} +# column: value diff --git a/test/functional/story_statuses_controller_test.rb b/test/functional/story_statuses_controller_test.rb new file mode 100644 index 0000000..95a0d48 --- /dev/null +++ b/test/functional/story_statuses_controller_test.rb @@ -0,0 +1,7 @@ +require 'test_helper' + +class StoryStatusesControllerTest < ActionController::TestCase + # test "the truth" do + # assert true + # end +end diff --git a/test/unit/story_status_test.rb b/test/unit/story_status_test.rb new file mode 100644 index 0000000..4b7efb3 --- /dev/null +++ b/test/unit/story_status_test.rb @@ -0,0 +1,7 @@ +require 'test_helper' + +class StoryStatusTest < ActiveSupport::TestCase + # test "the truth" do + # assert true + # end +end