diff options
Diffstat (limited to 'test')
-rw-r--r-- | test/fixtures/custom_fields.yml | 15 | ||||
-rw-r--r-- | test/fixtures/custom_values.yml | 7 | ||||
-rw-r--r-- | test/unit/enumeration_test.rb | 7 | ||||
-rw-r--r-- | test/unit/time_entry_activity_test.rb | 49 |
4 files changed, 75 insertions, 3 deletions
diff --git a/test/fixtures/custom_fields.yml b/test/fixtures/custom_fields.yml index b4b58c4d4..dcbef29d6 100644 --- a/test/fixtures/custom_fields.yml +++ b/test/fixtures/custom_fields.yml @@ -87,4 +87,17 @@ custom_fields_006: field_format: float default_value: "" editable: true -
\ No newline at end of file +custom_fields_007: + name: Billable + min_length: 0 + regexp: "" + is_for_all: false + is_filter: true + type: TimeEntryActivityCustomField + max_length: 0 + possible_values: "" + id: 7 + is_required: false + field_format: bool + default_value: "" + editable: true diff --git a/test/fixtures/custom_values.yml b/test/fixtures/custom_values.yml index 783aa75c9..4e6f4b3ff 100644 --- a/test/fixtures/custom_values.yml +++ b/test/fixtures/custom_values.yml @@ -83,4 +83,9 @@ custom_values_014: customized_id: 5 id: 14 value: "-7.6" -
\ No newline at end of file +custom_values_015: + customized_type: TimeEntryActivity + custom_field_id: 7 + customized_id: 10 + id: 15 + value: true diff --git a/test/unit/enumeration_test.rb b/test/unit/enumeration_test.rb index 4dc6e15c3..663077352 100644 --- a/test/unit/enumeration_test.rb +++ b/test/unit/enumeration_test.rb @@ -18,7 +18,7 @@ require File.dirname(__FILE__) + '/../test_helper' class EnumerationTest < ActiveSupport::TestCase - fixtures :enumerations, :issues + fixtures :enumerations, :issues, :custom_fields, :custom_values def setup end @@ -81,4 +81,9 @@ class EnumerationTest < ActiveSupport::TestCase assert_nil Issue.find(:first, :conditions => {:priority_id => 4}) assert_equal 5, Enumeration.find(6).objects_count end + + def test_should_be_customizable + assert Enumeration.included_modules.include?(Redmine::Acts::Customizable::InstanceMethods) + end + end diff --git a/test/unit/time_entry_activity_test.rb b/test/unit/time_entry_activity_test.rb index 9422a91ab..16077c0c9 100644 --- a/test/unit/time_entry_activity_test.rb +++ b/test/unit/time_entry_activity_test.rb @@ -32,5 +32,54 @@ class TimeEntryActivityTest < ActiveSupport::TestCase def test_option_name assert_equal :enumeration_activities, TimeEntryActivity.new.option_name end + + def test_create_with_custom_field + field = TimeEntryActivityCustomField.find_by_name('Billable') + e = TimeEntryActivity.new(:name => 'Custom Data') + e.custom_field_values = {field.id => "1"} + assert e.save + + e.reload + assert_equal "1", e.custom_value_for(field).value + end + + def test_create_without_required_custom_field_should_fail + field = TimeEntryActivityCustomField.find_by_name('Billable') + field.update_attribute(:is_required, true) + + e = TimeEntryActivity.new(:name => 'Custom Data') + assert !e.save + assert_equal I18n.translate('activerecord.errors.messages.invalid'), e.errors.on(:custom_values) + end + + def test_create_with_required_custom_field_should_succeed + field = TimeEntryActivityCustomField.find_by_name('Billable') + field.update_attribute(:is_required, true) + + e = TimeEntryActivity.new(:name => 'Custom Data') + e.custom_field_values = {field.id => "1"} + assert e.save + end + + def test_update_issue_with_required_custom_field_change + field = TimeEntryActivityCustomField.find_by_name('Billable') + field.update_attribute(:is_required, true) + + e = TimeEntryActivity.find(10) + assert e.available_custom_fields.include?(field) + # No change to custom field, record can be saved + assert e.save + # Blanking custom field, save should fail + e.custom_field_values = {field.id => ""} + assert !e.save + assert e.errors.on(:custom_values) + + # Update custom field to valid value, save should succeed + e.custom_field_values = {field.id => "0"} + assert e.save + e.reload + assert_equal "0", e.custom_value_for(field).value + end + end |