@@ -12,6 +12,36 module ActiveRecord | |||
|
12 | 12 | end |
|
13 | 13 | end |
|
14 | 14 | |
|
15 | module ActiveRecord | |
|
16 | class Errors | |
|
17 | def full_messages(options = {}) | |
|
18 | full_messages = [] | |
|
19 | ||
|
20 | @errors.each_key do |attr| | |
|
21 | @errors[attr].each do |message| | |
|
22 | next unless message | |
|
23 | ||
|
24 | if attr == "base" | |
|
25 | full_messages << message | |
|
26 | elsif attr == "custom_values" | |
|
27 | # Replace the generic "custom values is invalid" | |
|
28 | # with the errors on custom values | |
|
29 | @base.custom_values.each do |value| | |
|
30 | value.errors.each do |attr, msg| | |
|
31 | full_messages << value.custom_field.name + ' ' + msg | |
|
32 | end | |
|
33 | end | |
|
34 | else | |
|
35 | attr_name = @base.class.human_attribute_name(attr) | |
|
36 | full_messages << attr_name + ' ' + message | |
|
37 | end | |
|
38 | end | |
|
39 | end | |
|
40 | full_messages | |
|
41 | end | |
|
42 | end | |
|
43 | end | |
|
44 | ||
|
15 | 45 | module ActionView |
|
16 | 46 | module Helpers |
|
17 | 47 | module DateHelper |
@@ -63,6 +63,19 class IssueTest < Test::Unit::TestCase | |||
|
63 | 63 | assert_equal 'PostgreSQL', issue.custom_value_for(field).value |
|
64 | 64 | end |
|
65 | 65 | |
|
66 | def test_errors_full_messages_should_include_custom_fields_errors | |
|
67 | field = IssueCustomField.find_by_name('Database') | |
|
68 | ||
|
69 | issue = Issue.new(:project_id => 1, :tracker_id => 1, :author_id => 1, :status_id => 1, :subject => 'test_create', :description => 'IssueTest#test_create_with_required_custom_field') | |
|
70 | assert issue.available_custom_fields.include?(field) | |
|
71 | # Invalid value | |
|
72 | issue.custom_field_values = { field.id => 'SQLServer' } | |
|
73 | ||
|
74 | assert !issue.valid? | |
|
75 | assert_equal 1, issue.errors.full_messages.size | |
|
76 | assert_equal "Database #{I18n.translate('activerecord.errors.messages.inclusion')}", issue.errors.full_messages.first | |
|
77 | end | |
|
78 | ||
|
66 | 79 | def test_update_issue_with_required_custom_field |
|
67 | 80 | field = IssueCustomField.find_by_name('Database') |
|
68 | 81 | field.update_attribute(:is_required, true) |
General Comments 0
You need to be logged in to leave comments.
Login now