yukonisuru 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (96) hide show
  1. checksums.yaml +7 -0
  2. data/.coveralls.yml +1 -0
  3. data/.gitignore +14 -0
  4. data/.rspec +4 -0
  5. data/.travis.yml +13 -0
  6. data/Gemfile +4 -0
  7. data/LICENSE.txt +22 -0
  8. data/README.md +1101 -0
  9. data/Rakefile +1 -0
  10. data/config/locales/en.yml +113 -0
  11. data/lib/yukonisuru.rb +93 -0
  12. data/lib/yukonisuru/matchers/ensure_valid_alpha_format_of.rb +26 -0
  13. data/lib/yukonisuru/matchers/ensure_valid_alpha_numeric_format_of.rb +26 -0
  14. data/lib/yukonisuru/matchers/ensure_valid_base64_format_of.rb +26 -0
  15. data/lib/yukonisuru/matchers/ensure_valid_boolean_format_of.rb +26 -0
  16. data/lib/yukonisuru/matchers/ensure_valid_credit_card_format_of.rb +26 -0
  17. data/lib/yukonisuru/matchers/ensure_valid_currency_format_of.rb +26 -0
  18. data/lib/yukonisuru/matchers/ensure_valid_cusip_format_of.rb +26 -0
  19. data/lib/yukonisuru/matchers/ensure_valid_email_format_of.rb +26 -0
  20. data/lib/yukonisuru/matchers/ensure_valid_equality_matcher_of.rb +40 -0
  21. data/lib/yukonisuru/matchers/ensure_valid_gtin_format_of.rb +26 -0
  22. data/lib/yukonisuru/matchers/ensure_valid_hex_format_of.rb +26 -0
  23. data/lib/yukonisuru/matchers/ensure_valid_imei_format_of.rb +26 -0
  24. data/lib/yukonisuru/matchers/ensure_valid_ip_format_of.rb +26 -0
  25. data/lib/yukonisuru/matchers/ensure_valid_isbn_format_of.rb +26 -0
  26. data/lib/yukonisuru/matchers/ensure_valid_isin_format_of.rb +26 -0
  27. data/lib/yukonisuru/matchers/ensure_valid_latitude_format_of.rb +26 -0
  28. data/lib/yukonisuru/matchers/ensure_valid_longitude_format_of.rb +26 -0
  29. data/lib/yukonisuru/matchers/ensure_valid_mac_address_format_of.rb +26 -0
  30. data/lib/yukonisuru/matchers/ensure_valid_name_format_of.rb +26 -0
  31. data/lib/yukonisuru/matchers/ensure_valid_password_format_of.rb +26 -0
  32. data/lib/yukonisuru/matchers/ensure_valid_phone_format_of.rb +26 -0
  33. data/lib/yukonisuru/matchers/ensure_valid_sedol_format_of.rb +26 -0
  34. data/lib/yukonisuru/matchers/ensure_valid_slug_format_of.rb +26 -0
  35. data/lib/yukonisuru/matchers/ensure_valid_ssn_format_of.rb +26 -0
  36. data/lib/yukonisuru/matchers/ensure_valid_url_format_of.rb +26 -0
  37. data/lib/yukonisuru/matchers/ensure_valid_username_format_of.rb +26 -0
  38. data/lib/yukonisuru/matchers/ensure_valid_uuid_format_of.rb +26 -0
  39. data/lib/yukonisuru/validators/alpha_numeric_validator.rb +31 -0
  40. data/lib/yukonisuru/validators/alpha_validator.rb +31 -0
  41. data/lib/yukonisuru/validators/base64_validator.rb +9 -0
  42. data/lib/yukonisuru/validators/boolean_validator.rb +9 -0
  43. data/lib/yukonisuru/validators/credit_card_validator.rb +133 -0
  44. data/lib/yukonisuru/validators/currency_validator.rb +23 -0
  45. data/lib/yukonisuru/validators/cusip_validator.rb +33 -0
  46. data/lib/yukonisuru/validators/email_validator.rb +25 -0
  47. data/lib/yukonisuru/validators/equality_validator.rb +27 -0
  48. data/lib/yukonisuru/validators/gtin_validator.rb +59 -0
  49. data/lib/yukonisuru/validators/hex_validator.rb +9 -0
  50. data/lib/yukonisuru/validators/imei_validator.rb +37 -0
  51. data/lib/yukonisuru/validators/ip_validator.rb +9 -0
  52. data/lib/yukonisuru/validators/isbn_validator.rb +24 -0
  53. data/lib/yukonisuru/validators/isin_validator.rb +38 -0
  54. data/lib/yukonisuru/validators/latitude_validator.rb +9 -0
  55. data/lib/yukonisuru/validators/longitude_validator.rb +9 -0
  56. data/lib/yukonisuru/validators/mac_address_validator.rb +24 -0
  57. data/lib/yukonisuru/validators/name_validator.rb +9 -0
  58. data/lib/yukonisuru/validators/password_validator.rb +23 -0
  59. data/lib/yukonisuru/validators/phone_validator.rb +9 -0
  60. data/lib/yukonisuru/validators/sedol_validator.rb +32 -0
  61. data/lib/yukonisuru/validators/slug_validator.rb +9 -0
  62. data/lib/yukonisuru/validators/ssn_validator.rb +9 -0
  63. data/lib/yukonisuru/validators/url_validator.rb +36 -0
  64. data/lib/yukonisuru/validators/username_validator.rb +9 -0
  65. data/lib/yukonisuru/validators/uuid_validator.rb +28 -0
  66. data/lib/yukonisuru/version.rb +3 -0
  67. data/spec/lib/alpha_numeric_validator_spec.rb +91 -0
  68. data/spec/lib/alpha_validator_spec.rb +182 -0
  69. data/spec/lib/base64_validator_spec.rb +33 -0
  70. data/spec/lib/boolean_validator_spec.rb +35 -0
  71. data/spec/lib/credit_card_validator_spec.rb +686 -0
  72. data/spec/lib/currency_validator_spec.rb +63 -0
  73. data/spec/lib/cusip_validator_spec.rb +27 -0
  74. data/spec/lib/email_validator_spec.rb +109 -0
  75. data/spec/lib/equality_validator_spec.rb +334 -0
  76. data/spec/lib/gtin_validator_spec.rb +101 -0
  77. data/spec/lib/hex_validator_spec.rb +73 -0
  78. data/spec/lib/imei_validator_spec.rb +41 -0
  79. data/spec/lib/ip_validator_spec.rb +33 -0
  80. data/spec/lib/isbn_validator_spec.rb +41 -0
  81. data/spec/lib/isin_validator_spec.rb +35 -0
  82. data/spec/lib/latitude_validator_spec.rb +31 -0
  83. data/spec/lib/longitude_validator_spec.rb +31 -0
  84. data/spec/lib/mac_address_validator_spec.rb +54 -0
  85. data/spec/lib/name_validator_spec.rb +39 -0
  86. data/spec/lib/password_validator_spec.rb +87 -0
  87. data/spec/lib/phone_validator_spec.rb +42 -0
  88. data/spec/lib/sedol_validator_spec.rb +31 -0
  89. data/spec/lib/slug_validator_spec.rb +41 -0
  90. data/spec/lib/ssn_validator_spec.rb +36 -0
  91. data/spec/lib/url_validator_spec.rb +109 -0
  92. data/spec/lib/username_validator_spec.rb +37 -0
  93. data/spec/lib/uuid_validator_spec.rb +157 -0
  94. data/spec/spec_helper.rb +12 -0
  95. data/yukonisuru.gemspec +29 -0
  96. metadata +264 -0
@@ -0,0 +1,39 @@
1
+ require 'spec_helper'
2
+
3
+ describe NameValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :name, :email
10
+ validates :name, name: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("First Last").for(:name) }
17
+ it { should allow_value("First Last-Name").for(:name) }
18
+ it { should allow_value("First Middle Last").for(:name) }
19
+ it { should allow_value("Sur First Middle Last").for(:name) }
20
+ it { should allow_value("Sur First Middle Last Family").for(:name) }
21
+ it { should allow_value("Sur First Middle Last-Family").for(:name) }
22
+
23
+ it { should_not allow_value('').for(:name) }
24
+ it { should_not allow_value(' ').for(:name) }
25
+ it { should_not allow_value(nil).for(:name) }
26
+ it { should_not allow_value("First").for(:name) }
27
+ it { should_not allow_value("First Last_Name").for(:name) }
28
+ it { should_not allow_value("First1 Last").for(:name) }
29
+ it { should_not allow_value("First 1 Last").for(:name) }
30
+ it { should_not allow_value("Sur. First Middle Last Jr.").for(:name) }
31
+ it { should_not allow_value("Sur First Middle Last Family III").for(:name) }
32
+ it { should_not allow_value("! \#$%\`|").for(:name) }
33
+ it { should_not allow_value("<>@[]\`|").for(:name) }
34
+
35
+ it { should ensure_valid_name_format_of(:name) }
36
+ it { should_not ensure_valid_name_format_of(:email) }
37
+ end
38
+
39
+ end
@@ -0,0 +1,87 @@
1
+ require 'spec_helper'
2
+
3
+ describe PasswordValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :password, :name
10
+ validates :password, password: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("password").for(:password) }
17
+ it { should allow_value("password1234").for(:password) }
18
+ it { should allow_value("pa$$word").for(:password) }
19
+ it { should allow_value("pass-word").for(:password) }
20
+ it { should allow_value("pass_word").for(:password) }
21
+ it { should allow_value("password!").for(:password) }
22
+ it { should allow_value("password@").for(:password) }
23
+ it { should allow_value("password#").for(:password) }
24
+ it { should allow_value("password%").for(:password) }
25
+ it { should allow_value("password^").for(:password) }
26
+ it { should allow_value("password&").for(:password) }
27
+ it { should allow_value("password*").for(:password) }
28
+
29
+ it { should_not allow_value('').for(:password) }
30
+ it { should_not allow_value(' ').for(:password) }
31
+ it { should_not allow_value(nil).for(:password) }
32
+ it { should_not allow_value("pass").for(:password) }
33
+ it { should_not allow_value(" password").for(:password) }
34
+ it { should_not allow_value(" password ").for(:password) }
35
+ it { should_not allow_value("password ").for(:password) }
36
+ it { should_not allow_value("pass word").for(:password) }
37
+ it { should_not allow_value("password-12345678910").for(:password) }
38
+ it { should_not allow_value("! \#$%\`|").for(:password) }
39
+ it { should_not allow_value("<>@[]\`|").for(:password) }
40
+
41
+ it { should ensure_valid_password_format_of(:password) }
42
+ it { should_not ensure_valid_password_format_of(:name) }
43
+ end
44
+
45
+ context "Password with :strict option has a valid value" do
46
+ let(:klass) do
47
+ Class.new do
48
+ include ActiveModel::Validations
49
+ attr_accessor :password, :name
50
+ validates :password, password: { strict: true }
51
+ end
52
+ end
53
+
54
+ subject { klass.new }
55
+
56
+ it { should allow_value("Password123").for(:password) }
57
+ it { should allow_value("Password-123").for(:password) }
58
+
59
+ it { should_not allow_value('').for(:password) }
60
+ it { should_not allow_value(' ').for(:password) }
61
+ it { should_not allow_value(nil).for(:password) }
62
+ it { should_not allow_value("pass").for(:password) }
63
+ it { should_not allow_value(" password").for(:password) }
64
+ it { should_not allow_value(" password ").for(:password) }
65
+ it { should_not allow_value("password ").for(:password) }
66
+ it { should_not allow_value("pass word").for(:password) }
67
+ it { should_not allow_value("password-12345678910").for(:password) }
68
+ it { should_not allow_value("password").for(:password) }
69
+ it { should_not allow_value("password1234").for(:password) }
70
+ it { should_not allow_value("pa$$word").for(:password) }
71
+ it { should_not allow_value("pass-word").for(:password) }
72
+ it { should_not allow_value("pass_word").for(:password) }
73
+ it { should_not allow_value("password!").for(:password) }
74
+ it { should_not allow_value("password@").for(:password) }
75
+ it { should_not allow_value("password#").for(:password) }
76
+ it { should_not allow_value("password%").for(:password) }
77
+ it { should_not allow_value("password^").for(:password) }
78
+ it { should_not allow_value("password&").for(:password) }
79
+ it { should_not allow_value("password*").for(:password) }
80
+ it { should_not allow_value("! \#$%\`|").for(:password) }
81
+ it { should_not allow_value("<>@[]\`|").for(:password) }
82
+
83
+ it { should ensure_valid_password_format_of(:password) }
84
+ it { should_not ensure_valid_password_format_of(:name) }
85
+ end
86
+
87
+ end
@@ -0,0 +1,42 @@
1
+ require 'spec_helper'
2
+
3
+ describe PhoneValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :phone, :name
10
+ validates :phone, phone: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("1234567").for(:phone) }
17
+ it { should allow_value("123-4567").for(:phone) }
18
+ it { should allow_value("123 4567").for(:phone) }
19
+ it { should allow_value("5551234567").for(:phone) }
20
+ it { should allow_value("555-123-4567").for(:phone) }
21
+ it { should allow_value("555 123 4567").for(:phone) }
22
+ it { should allow_value("(555) 123-4567").for(:phone) }
23
+ it { should allow_value("(555) 123-4567 ext 1234").for(:phone) }
24
+ it { should allow_value("(555) 123-4567 ext1234").for(:phone) }
25
+ it { should allow_value("(555) 123-4567 ext-1234").for(:phone) }
26
+ it { should allow_value("1-555-123-4567").for(:phone) }
27
+ it { should allow_value("+1-555-123-4567").for(:phone) }
28
+ it { should allow_value("+1 (555) 123-4567 ext-1234").for(:phone) }
29
+
30
+ it { should_not allow_value('').for(:phone) }
31
+ it { should_not allow_value(nil).for(:phone) }
32
+ it { should_not allow_value("123_4567").for(:phone) }
33
+ it { should_not allow_value("(555) 123-4567 ext:1234").for(:phone) }
34
+ it { should_not allow_value("(555) 123-4567 ext_1234").for(:phone) }
35
+ it { should_not allow_value("! \#$%\`|").for(:phone) }
36
+ it { should_not allow_value("<>@[]\`|").for(:phone) }
37
+
38
+ it { should ensure_valid_phone_format_of(:phone) }
39
+ it { should_not ensure_valid_phone_format_of(:name) }
40
+ end
41
+
42
+ end
@@ -0,0 +1,31 @@
1
+ require 'spec_helper'
2
+
3
+ describe SedolValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :sedol, :name
10
+ validates :sedol, sedol: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("B0WNLY7").for(:sedol) }
17
+
18
+ it { should_not allow_value('').for(:sedol) }
19
+ it { should_not allow_value(' ').for(:sedol) }
20
+ it { should_not allow_value(nil).for(:sedol) }
21
+ it { should_not allow_value("B0WNL").for(:sedol) }
22
+ it { should_not allow_value("B0WNLY").for(:sedol) }
23
+ it { should_not allow_value("B0WNLY77").for(:sedol) }
24
+ it { should_not allow_value("! \#$%\`|").for(:sedol) }
25
+ it { should_not allow_value("<>@[]\`|").for(:sedol) }
26
+
27
+ it { should ensure_valid_sedol_format_of(:sedol) }
28
+ it { should_not ensure_valid_sedol_format_of(:name) }
29
+ end
30
+
31
+ end
@@ -0,0 +1,41 @@
1
+ require 'spec_helper'
2
+
3
+ describe SlugValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :slug, :name
10
+ validates :slug, slug: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("slug").for(:slug) }
17
+ it { should allow_value("slug1234").for(:slug) }
18
+ it { should allow_value("slug-word").for(:slug) }
19
+ it { should allow_value("slug-1234").for(:slug) }
20
+
21
+ it { should_not allow_value('').for(:slug) }
22
+ it { should_not allow_value(' ').for(:slug) }
23
+ it { should_not allow_value(nil).for(:slug) }
24
+ it { should_not allow_value(" slug").for(:slug) }
25
+ it { should_not allow_value(" slug ").for(:slug) }
26
+ it { should_not allow_value("slug ").for(:slug) }
27
+ it { should_not allow_value(" 1234").for(:slug) }
28
+ it { should_not allow_value(" 1234 ").for(:slug) }
29
+ it { should_not allow_value("1234 ").for(:slug) }
30
+ it { should_not allow_value("slug word").for(:slug) }
31
+ it { should_not allow_value("slug 1234").for(:slug) }
32
+ it { should_not allow_value("slug_word").for(:slug) }
33
+ it { should_not allow_value("slug_1234").for(:slug) }
34
+ it { should_not allow_value("! \#$%\`|").for(:slug) }
35
+ it { should_not allow_value("<>@[]\`|").for(:slug) }
36
+
37
+ it { should ensure_valid_slug_format_of(:slug) }
38
+ it { should_not ensure_valid_slug_format_of(:name) }
39
+ end
40
+
41
+ end
@@ -0,0 +1,36 @@
1
+ require 'spec_helper'
2
+
3
+ describe SsnValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :ssn, :name
10
+ validates :ssn, ssn: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("333-22-4444").for(:ssn) }
17
+ it { should allow_value("333224444").for(:ssn) }
18
+
19
+ it { should_not allow_value('').for(:ssn) }
20
+ it { should_not allow_value(' ').for(:ssn) }
21
+ it { should_not allow_value(nil).for(:ssn) }
22
+ it { should_not allow_value(" 333-22-4444").for(:ssn) }
23
+ it { should_not allow_value(" 333-22-4444 ").for(:ssn) }
24
+ it { should_not allow_value("333-22-4444 ").for(:ssn) }
25
+ it { should_not allow_value("333 22 4444").for(:ssn) }
26
+ it { should_not allow_value("333-22-444n").for(:ssn) }
27
+ it { should_not allow_value("333 22 4444").for(:ssn) }
28
+ it { should_not allow_value("3-2-4").for(:ssn) }
29
+ it { should_not allow_value("! \#$%\`|").for(:ssn) }
30
+ it { should_not allow_value("<>@[]\`|").for(:ssn) }
31
+
32
+ it { should ensure_valid_ssn_format_of(:ssn) }
33
+ it { should_not ensure_valid_ssn_format_of(:name) }
34
+ end
35
+
36
+ end
@@ -0,0 +1,109 @@
1
+ require 'spec_helper'
2
+
3
+ describe UrlValidator do
4
+
5
+ context "has valid format" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :url, :name
10
+ validates :url, url: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should ensure_valid_url_format_of(:url) }
17
+ it { should_not ensure_valid_url_format_of(:name) }
18
+
19
+ it { should allow_value("http://example.com").for(:url) }
20
+ it { should allow_value("http://FooBar.cOm").for(:url) }
21
+ it { should allow_value("http://foo.bar.baz.com").for(:url) }
22
+ it { should allow_value("http://123.com").for(:url) }
23
+ it { should allow_value("http://www.example.ru").for(:url) }
24
+ it { should allow_value("http://user-example.co.uk").for(:url) }
25
+ it { should allow_value("https://example.com").for(:url) }
26
+ it { should allow_value("http://example.org/").for(:url) }
27
+ it { should allow_value("https://example.net/index.html").for(:url) }
28
+ it { should allow_value("http://example.net/login.php").for(:url) }
29
+ it { should allow_value("https://example.travel/").for(:url) }
30
+ it { should allow_value("http://example.aero").for(:url) }
31
+ it { should allow_value("http://example.aero?foo=bar").for(:url) }
32
+
33
+ it { should_not allow_value('').for(:url) }
34
+ it { should_not allow_value(' ').for(:url) }
35
+ it { should_not allow_value(nil).for(:url) }
36
+ it { should_not allow_value("example").for(:url) }
37
+ it { should_not allow_value("http://user_examplecom").for(:url) }
38
+ it { should_not allow_value("http://user_example.com").for(:url) }
39
+ it { should_not allow_value("http://user_example.a").for(:url) }
40
+ it { should_not allow_value("ftp://foo.bar.baz.com").for(:url) }
41
+ end
42
+
43
+ describe "url must be in a specific domain" do
44
+ let(:klass) do
45
+ Class.new do
46
+ include ActiveModel::Validations
47
+ attr_accessor :url1, :url2
48
+ validates :url1, url: { domain: :org }
49
+ validates :url2, url: { domain: [:org, 'edu', 'Com.Au'] }
50
+ end
51
+ end
52
+
53
+ subject { klass.new }
54
+
55
+ it { should allow_value("http://example.org").for(:url1) }
56
+ it { should_not allow_value("http://example.com").for(:url1) }
57
+
58
+ it { should allow_value("http://example.org").for(:url2) }
59
+ it { should allow_value("http://example.edu").for(:url2) }
60
+ it { should allow_value("http://example.com.au").for(:url2) }
61
+ it { should allow_value("http://example.Com.Au").for(:url2) }
62
+ it { should_not allow_value("http://example.com").for(:url2) }
63
+ end
64
+
65
+ describe "url must be domain root" do
66
+ let(:klass) do
67
+ Class.new do
68
+ include ActiveModel::Validations
69
+ attr_accessor :url1, :url2
70
+ validates :url1, url: { root: true }
71
+ validates :url2, url: { root: false }
72
+ end
73
+ end
74
+
75
+ subject { klass.new }
76
+
77
+ it { should allow_value("http://example.org").for(:url1) }
78
+ it { should allow_value("http://example.org/").for(:url1) }
79
+ it { should_not allow_value("http://example.com/test").for(:url1) }
80
+ it { should_not allow_value("http://example.com/#fragment").for(:url1) }
81
+ it { should_not allow_value("http://example.com/?key=value").for(:url1) }
82
+
83
+
84
+ it { should allow_value("http://example.org").for(:url2) }
85
+ it { should allow_value("http://example.org/lorem").for(:url2) }
86
+ end
87
+
88
+ describe "url must have a specific scheme" do
89
+ let(:klass) do
90
+ Class.new do
91
+ include ActiveModel::Validations
92
+ attr_accessor :url1, :url2
93
+ validates :url1, url: { scheme: 'http' }
94
+ validates :url2, url: { scheme: ['HTTP', :https] }
95
+ end
96
+ end
97
+
98
+ subject { klass.new }
99
+
100
+ it { should allow_value("http://example.org").for(:url1) }
101
+ it { should_not allow_value("https://example.org").for(:url1) }
102
+
103
+ it { should allow_value("http://example.org").for(:url2) }
104
+ it { should allow_value("https://example.org").for(:url2) }
105
+ it { should allow_value("HTTPS://example.org").for(:url2) }
106
+ it { should_not allow_value("ftp://example.org").for(:url2) }
107
+ end
108
+
109
+ end
@@ -0,0 +1,37 @@
1
+ require 'spec_helper'
2
+
3
+ describe UsernameValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :username, :name
10
+ validates :username, username: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("username").for(:username) }
17
+ it { should allow_value("username123").for(:username) }
18
+ it { should allow_value("username_123").for(:username) }
19
+ it { should allow_value("username-123").for(:username) }
20
+
21
+ it { should_not allow_value('').for(:username) }
22
+ it { should_not allow_value(' ').for(:username) }
23
+ it { should_not allow_value(nil).for(:username) }
24
+ it { should_not allow_value("u").for(:username) }
25
+ it { should_not allow_value(" username").for(:username) }
26
+ it { should_not allow_value(" username ").for(:username) }
27
+ it { should_not allow_value("username ").for(:username) }
28
+ it { should_not allow_value("user name").for(:username) }
29
+ it { should_not allow_value("username-123456789").for(:username) }
30
+ it { should_not allow_value("! \#$%\`|").for(:username) }
31
+ it { should_not allow_value("<>@[]\`|").for(:username) }
32
+
33
+ it { should ensure_valid_username_format_of(:username) }
34
+ it { should_not ensure_valid_username_format_of(:name) }
35
+ end
36
+
37
+ end
@@ -0,0 +1,157 @@
1
+ require 'spec_helper'
2
+
3
+ describe UuidValidator do
4
+
5
+ context "has a valid value" do
6
+ let(:klass) do
7
+ Class.new do
8
+ include ActiveModel::Validations
9
+ attr_accessor :uuid, :name
10
+ validates :uuid, uuid: true
11
+ end
12
+ end
13
+
14
+ subject { klass.new }
15
+
16
+ it { should allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e").for(:uuid) }
17
+ it { should allow_value("16fd2706-8baf-433b-82eb-8c7fada847da").for(:uuid) }
18
+ it { should allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d").for(:uuid) }
19
+ it { should allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e").for(:uuid) }
20
+
21
+ it { should_not allow_value('').for(:uuid) }
22
+ it { should_not allow_value(' ').for(:uuid) }
23
+ it { should_not allow_value(nil).for(:uuid) }
24
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e1").for(:uuid) }
25
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847da1").for(:uuid) }
26
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d1").for(:uuid) }
27
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e1").for(:uuid) }
28
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355").for(:uuid) }
29
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847d").for(:uuid) }
30
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5").for(:uuid) }
31
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1").for(:uuid) }
32
+ it { should_not allow_value("6fa459eaee8a3ca4894edb77e160355e").for(:uuid) }
33
+ it { should_not allow_value("16fd27068baf433b82eb8c7fada847da").for(:uuid) }
34
+ it { should_not allow_value("886313e13b8a53729b900c9aee199e5d").for(:uuid) }
35
+ it { should_not allow_value("a8098c1af86e11dabd1a00112444be1e").for(:uuid) }
36
+ it { should_not allow_value("! \#$%\`|").for(:uuid) }
37
+ it { should_not allow_value("<>@[]\`|").for(:uuid) }
38
+
39
+ it { should ensure_valid_uuid_format_of(:uuid) }
40
+ it { should_not ensure_valid_uuid_format_of(:name) }
41
+ end
42
+
43
+ context "with version: 3 option has a valid value" do
44
+ let(:klass) do
45
+ Class.new do
46
+ include ActiveModel::Validations
47
+ attr_accessor :uuid, :name
48
+ validates :uuid, uuid: { version: 3 }
49
+ end
50
+ end
51
+
52
+ subject { klass.new }
53
+
54
+ it { should allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e").for(:uuid) }
55
+
56
+ it { should_not allow_value('').for(:uuid) }
57
+ it { should_not allow_value(' ').for(:uuid) }
58
+ it { should_not allow_value(nil).for(:uuid) }
59
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847da").for(:uuid) }
60
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d").for(:uuid) }
61
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e").for(:uuid) }
62
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e1").for(:uuid) }
63
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847da1").for(:uuid) }
64
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d1").for(:uuid) }
65
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e1").for(:uuid) }
66
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355").for(:uuid) }
67
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847d").for(:uuid) }
68
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5").for(:uuid) }
69
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1").for(:uuid) }
70
+ it { should_not allow_value("6fa459eaee8a3ca4894edb77e160355e").for(:uuid) }
71
+ it { should_not allow_value("16fd27068baf433b82eb8c7fada847da").for(:uuid) }
72
+ it { should_not allow_value("886313e13b8a53729b900c9aee199e5d").for(:uuid) }
73
+ it { should_not allow_value("a8098c1af86e11dabd1a00112444be1e").for(:uuid) }
74
+ it { should_not allow_value("! \#$%\`|").for(:uuid) }
75
+ it { should_not allow_value("<>@[]\`|").for(:uuid) }
76
+
77
+ it { should ensure_valid_uuid_format_of(:uuid) }
78
+ it { should_not ensure_valid_uuid_format_of(:name) }
79
+ end
80
+
81
+ context "with version: 4 option has a valid value" do
82
+ let(:klass) do
83
+ Class.new do
84
+ include ActiveModel::Validations
85
+ attr_accessor :uuid, :name
86
+ validates :uuid, uuid: { version: 4 }
87
+ end
88
+ end
89
+
90
+ subject { klass.new }
91
+
92
+ it { should allow_value("16fd2706-8baf-433b-82eb-8c7fada847da").for(:uuid) }
93
+
94
+ it { should_not allow_value('').for(:uuid) }
95
+ it { should_not allow_value(' ').for(:uuid) }
96
+ it { should_not allow_value(nil).for(:uuid) }
97
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e").for(:uuid) }
98
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d").for(:uuid) }
99
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e").for(:uuid) }
100
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e1").for(:uuid) }
101
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847da1").for(:uuid) }
102
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d1").for(:uuid) }
103
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e1").for(:uuid) }
104
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355").for(:uuid) }
105
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847d").for(:uuid) }
106
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5").for(:uuid) }
107
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1").for(:uuid) }
108
+ it { should_not allow_value("6fa459eaee8a3ca4894edb77e160355e").for(:uuid) }
109
+ it { should_not allow_value("16fd27068baf433b82eb8c7fada847da").for(:uuid) }
110
+ it { should_not allow_value("886313e13b8a53729b900c9aee199e5d").for(:uuid) }
111
+ it { should_not allow_value("a8098c1af86e11dabd1a00112444be1e").for(:uuid) }
112
+ it { should_not allow_value("! \#$%\`|").for(:uuid) }
113
+ it { should_not allow_value("<>@[]\`|").for(:uuid) }
114
+
115
+ it { should ensure_valid_uuid_format_of(:uuid) }
116
+ it { should_not ensure_valid_uuid_format_of(:name) }
117
+ end
118
+
119
+ context "with version: 5 option has a valid value" do
120
+ let(:klass) do
121
+ Class.new do
122
+ include ActiveModel::Validations
123
+ attr_accessor :uuid, :name
124
+ validates :uuid, uuid: { version: 5 }
125
+ end
126
+ end
127
+
128
+ subject { klass.new }
129
+
130
+ it { should allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d").for(:uuid) }
131
+
132
+ it { should_not allow_value('').for(:uuid) }
133
+ it { should_not allow_value(' ').for(:uuid) }
134
+ it { should_not allow_value(nil).for(:uuid) }
135
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e").for(:uuid) }
136
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847da").for(:uuid) }
137
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e").for(:uuid) }
138
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355e1").for(:uuid) }
139
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847da1").for(:uuid) }
140
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5d1").for(:uuid) }
141
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1e1").for(:uuid) }
142
+ it { should_not allow_value("6fa459ea-ee8a-3ca4-894e-db77e160355").for(:uuid) }
143
+ it { should_not allow_value("16fd2706-8baf-433b-82eb-8c7fada847d").for(:uuid) }
144
+ it { should_not allow_value("886313e1-3b8a-5372-9b90-0c9aee199e5").for(:uuid) }
145
+ it { should_not allow_value("a8098c1a-f86e-11da-bd1a-00112444be1").for(:uuid) }
146
+ it { should_not allow_value("6fa459eaee8a3ca4894edb77e160355e").for(:uuid) }
147
+ it { should_not allow_value("16fd27068baf433b82eb8c7fada847da").for(:uuid) }
148
+ it { should_not allow_value("886313e13b8a53729b900c9aee199e5d").for(:uuid) }
149
+ it { should_not allow_value("a8098c1af86e11dabd1a00112444be1e").for(:uuid) }
150
+ it { should_not allow_value("! \#$%\`|").for(:uuid) }
151
+ it { should_not allow_value("<>@[]\`|").for(:uuid) }
152
+
153
+ it { should ensure_valid_uuid_format_of(:uuid) }
154
+ it { should_not ensure_valid_uuid_format_of(:name) }
155
+ end
156
+
157
+ end