br_documents 0.0.15 → 0.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/.github/workflows/config.yml +54 -0
- data/.gitignore +1 -1
- data/.rubocop.yml +65 -0
- data/Gemfile +1 -1
- data/Gemfile.lock +100 -0
- data/README.md +58 -1
- data/Rakefile +3 -3
- data/br_documents.gemspec +23 -19
- data/lib/br_documents.rb +3 -3
- data/lib/br_documents/cnpj_cpf/cnpj.rb +2 -2
- data/lib/br_documents/cnpj_cpf/cpf.rb +2 -2
- data/lib/br_documents/cnpj_cpf/document.rb +9 -9
- data/lib/br_documents/cnpj_validator.rb +4 -4
- data/lib/br_documents/commons/mod11.rb +1 -2
- data/lib/br_documents/commons/mod14.rb +20 -0
- data/lib/br_documents/cpf_validator.rb +4 -4
- data/lib/br_documents/gtin/gtin.rb +28 -0
- data/lib/br_documents/gtin_validator.rb +8 -0
- data/lib/br_documents/ie/ac.rb +3 -2
- data/lib/br_documents/ie/al.rb +2 -1
- data/lib/br_documents/ie/am.rb +3 -2
- data/lib/br_documents/ie/ap.rb +20 -16
- data/lib/br_documents/ie/ba.rb +28 -25
- data/lib/br_documents/ie/base.rb +1 -1
- data/lib/br_documents/ie/ce.rb +3 -2
- data/lib/br_documents/ie/df.rb +3 -2
- data/lib/br_documents/ie/es.rb +2 -1
- data/lib/br_documents/ie/factory.rb +3 -3
- data/lib/br_documents/ie/go.rb +3 -2
- data/lib/br_documents/ie/ma.rb +2 -1
- data/lib/br_documents/ie/mg.rb +14 -17
- data/lib/br_documents/ie/ms.rb +2 -1
- data/lib/br_documents/ie/mt.rb +6 -5
- data/lib/br_documents/ie/pa.rb +3 -2
- data/lib/br_documents/ie/pattern1.rb +10 -7
- data/lib/br_documents/ie/pattern2.rb +9 -8
- data/lib/br_documents/ie/pb.rb +3 -2
- data/lib/br_documents/ie/pe.rb +10 -10
- data/lib/br_documents/ie/pi.rb +2 -1
- data/lib/br_documents/ie/pr.rb +3 -2
- data/lib/br_documents/ie/rj.rb +3 -2
- data/lib/br_documents/ie/rn.rb +19 -16
- data/lib/br_documents/ie/ro.rb +17 -14
- data/lib/br_documents/ie/rr.rb +4 -3
- data/lib/br_documents/ie/rs.rb +3 -2
- data/lib/br_documents/ie/sc.rb +3 -2
- data/lib/br_documents/ie/se.rb +3 -2
- data/lib/br_documents/ie/sp.rb +17 -14
- data/lib/br_documents/ie/to.rb +6 -5
- data/lib/br_documents/ie_validator.rb +16 -15
- data/lib/br_documents/suframa/suframa.rb +60 -0
- data/lib/br_documents/suframa_validator.rb +8 -0
- data/lib/br_documents/version.rb +1 -1
- data/spec/cnpj_cpf/cnpj_spec.rb +21 -21
- data/spec/cnpj_cpf/cpf_spec.rb +21 -21
- data/spec/cnpj_validator_spec.rb +12 -12
- data/spec/cpf_validator_spec.rb +12 -12
- data/spec/gtin/gtin_spec.rb +49 -0
- data/spec/gtin_validator_spec.rb +47 -0
- data/spec/ie/ac_spec.rb +16 -16
- data/spec/ie/al_spec.rb +14 -14
- data/spec/ie/am_spec.rb +16 -16
- data/spec/ie/ap_spec.rb +14 -14
- data/spec/ie/ba_spec.rb +28 -28
- data/spec/ie/ce_spec.rb +9 -9
- data/spec/ie/df_spec.rb +16 -16
- data/spec/ie/es_spec.rb +9 -9
- data/spec/ie/factory_spec.rb +88 -89
- data/spec/ie/go_spec.rb +16 -16
- data/spec/ie/ma_spec.rb +9 -9
- data/spec/ie/mg_spec.rb +16 -16
- data/spec/ie/ms_spec.rb +9 -9
- data/spec/ie/mt_spec.rb +17 -17
- data/spec/ie/pa_spec.rb +16 -16
- data/spec/ie/pb_spec.rb +9 -9
- data/spec/ie/pe_spec.rb +27 -27
- data/spec/ie/pi_spec.rb +9 -9
- data/spec/ie/pr_spec.rb +14 -14
- data/spec/ie/rj_spec.rb +16 -16
- data/spec/ie/rn_spec.rb +27 -27
- data/spec/ie/ro_spec.rb +27 -27
- data/spec/ie/rr_spec.rb +16 -16
- data/spec/ie/rs_spec.rb +16 -16
- data/spec/ie/sc_spec.rb +16 -16
- data/spec/ie/se_spec.rb +9 -9
- data/spec/ie/shared_examples_for_pattern1.rb +11 -11
- data/spec/ie/shared_examples_for_to_remove_all_masks.rb +7 -8
- data/spec/ie/sp_spec.rb +19 -19
- data/spec/ie/to_spec.rb +35 -35
- data/spec/ie_validator_spec.rb +43 -31
- data/spec/spec_helper.rb +9 -6
- data/spec/suframa/suframa_spec.rb +109 -0
- data/spec/suframa_validator_spec.rb +36 -0
- data/spec/support/utilities.rb +2 -2
- metadata +94 -25
- data/.travis.yml +0 -6
- data/circle.yml +0 -3
data/spec/ie/rn_spec.rb
CHANGED
@@ -1,62 +1,62 @@
|
|
1
|
-
require
|
2
|
-
require_relative
|
1
|
+
require 'spec_helper'
|
2
|
+
require_relative 'shared_examples_for_to_remove_all_masks'
|
3
3
|
|
4
4
|
describe BrDocuments::IE::RN do
|
5
|
-
describe
|
6
|
-
context
|
7
|
-
it
|
8
|
-
ie = described_class.new(
|
9
|
-
expect(ie.formatted).to eq
|
5
|
+
describe '#formatted' do
|
6
|
+
context 'when having 9 digits' do
|
7
|
+
it 'returns a formatted ie' do
|
8
|
+
ie = described_class.new('123456789')
|
9
|
+
expect(ie.formatted).to eq '12.345.678-9'
|
10
10
|
end
|
11
11
|
end
|
12
12
|
|
13
|
-
context
|
14
|
-
it
|
15
|
-
ie = described_class.new(
|
16
|
-
expect(ie.formatted).to eq
|
13
|
+
context 'when having 10 digits' do
|
14
|
+
it 'returns a formatted ie' do
|
15
|
+
ie = described_class.new('1234567890')
|
16
|
+
expect(ie.formatted).to eq '12.3.456.789-0'
|
17
17
|
end
|
18
18
|
end
|
19
19
|
end
|
20
20
|
|
21
|
-
describe
|
22
|
-
it
|
23
|
-
[
|
21
|
+
describe '#valid?' do
|
22
|
+
it 'is invalid with malformed number' do
|
23
|
+
['9.012.207-95', '617.964.80-7', '25.9AB.924-6'].each do |number|
|
24
24
|
ie = described_class.new(number)
|
25
25
|
expect(ie).to_not be_valid
|
26
26
|
end
|
27
27
|
end
|
28
28
|
|
29
|
-
it
|
30
|
-
[
|
29
|
+
it 'is invalid with length different to 9 or 10' do
|
30
|
+
['12345678', '12345678901'].each do |number|
|
31
31
|
ie = described_class.new(number)
|
32
32
|
expect(ie).to_not be_valid
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
|
-
context
|
37
|
-
it
|
38
|
-
ie = described_class.new(
|
36
|
+
context 'when having 9 digits' do
|
37
|
+
it 'is invalid with invalid check number' do
|
38
|
+
ie = described_class.new('794050643')
|
39
39
|
expect(ie).to_not be_valid
|
40
40
|
end
|
41
41
|
|
42
|
-
it
|
43
|
-
ie = described_class.new(
|
42
|
+
it 'is valid with valid number' do
|
43
|
+
ie = described_class.new('200400401')
|
44
44
|
expect(ie).to be_valid
|
45
45
|
end
|
46
46
|
end
|
47
47
|
|
48
|
-
context
|
49
|
-
it
|
50
|
-
ie = described_class.new(
|
48
|
+
context 'when having 10 digits' do
|
49
|
+
it 'is invalid with invalid check number' do
|
50
|
+
ie = described_class.new('1153296142')
|
51
51
|
expect(ie).to_not be_valid
|
52
52
|
end
|
53
53
|
|
54
|
-
it
|
55
|
-
ie = described_class.new(
|
54
|
+
it 'is valid with valid number' do
|
55
|
+
ie = described_class.new('2000400400')
|
56
56
|
expect(ie).to be_valid
|
57
57
|
end
|
58
58
|
end
|
59
59
|
|
60
|
-
include_examples
|
60
|
+
include_examples 'for to remove all masks', '20.0.040.040-0'
|
61
61
|
end
|
62
62
|
end
|
data/spec/ie/ro_spec.rb
CHANGED
@@ -1,62 +1,62 @@
|
|
1
|
-
require
|
2
|
-
require_relative
|
1
|
+
require 'spec_helper'
|
2
|
+
require_relative 'shared_examples_for_to_remove_all_masks'
|
3
3
|
|
4
4
|
describe BrDocuments::IE::RO do
|
5
|
-
describe
|
6
|
-
context
|
7
|
-
it
|
8
|
-
ie = described_class.new(
|
9
|
-
expect(ie.formatted).to eq
|
5
|
+
describe '#formatted' do
|
6
|
+
context 'when having 9 digits' do
|
7
|
+
it 'returns a formatted ie' do
|
8
|
+
ie = described_class.new('123456789')
|
9
|
+
expect(ie.formatted).to eq '123.45678-9'
|
10
10
|
end
|
11
11
|
end
|
12
12
|
|
13
|
-
context
|
14
|
-
it
|
15
|
-
ie = described_class.new(
|
16
|
-
expect(ie.formatted).to eq
|
13
|
+
context 'when having 14 digits' do
|
14
|
+
it 'returns a formatted ie' do
|
15
|
+
ie = described_class.new('12345678901234')
|
16
|
+
expect(ie.formatted).to eq '1234567890123-4'
|
17
17
|
end
|
18
18
|
end
|
19
19
|
end
|
20
20
|
|
21
|
-
describe
|
22
|
-
it
|
23
|
-
[
|
21
|
+
describe '#valid?' do
|
22
|
+
it 'is invalid with malformed number' do
|
23
|
+
['20.049.788-6', '2.004.978-86', '937.03AB1-6'].each do |number|
|
24
24
|
ie = described_class.new(number)
|
25
25
|
expect(ie).to_not be_valid
|
26
26
|
end
|
27
27
|
end
|
28
28
|
|
29
|
-
it
|
30
|
-
[
|
29
|
+
it 'is invalid with length different to 9 or 14' do
|
30
|
+
['1234567', '123456789012', '12345678901234567'].each do |number|
|
31
31
|
ie = described_class.new(number)
|
32
32
|
expect(ie).to_not be_valid
|
33
33
|
end
|
34
34
|
end
|
35
35
|
|
36
|
-
context
|
37
|
-
it
|
38
|
-
ie = described_class.new(
|
36
|
+
context 'when having 9 digits' do
|
37
|
+
it 'is invalid with invalid check number' do
|
38
|
+
ie = described_class.new('134725252')
|
39
39
|
expect(ie).to_not be_valid
|
40
40
|
end
|
41
41
|
|
42
|
-
it
|
43
|
-
ie = described_class.new(
|
42
|
+
it 'is valid with valid number' do
|
43
|
+
ie = described_class.new('101625213')
|
44
44
|
expect(ie).to be_valid
|
45
45
|
end
|
46
46
|
end
|
47
47
|
|
48
|
-
context
|
49
|
-
it
|
50
|
-
ie = described_class.new(
|
48
|
+
context 'when having 14 digits' do
|
49
|
+
it 'is invalid with invalid check number' do
|
50
|
+
ie = described_class.new('02539835229263')
|
51
51
|
expect(ie).to_not be_valid
|
52
52
|
end
|
53
53
|
|
54
|
-
it
|
55
|
-
ie = described_class.new(
|
54
|
+
it 'is valid with valid number' do
|
55
|
+
ie = described_class.new('00000003497861')
|
56
56
|
expect(ie).to be_valid
|
57
57
|
end
|
58
58
|
end
|
59
59
|
|
60
|
-
include_examples
|
60
|
+
include_examples 'for to remove all masks', '0000000062521-3'
|
61
61
|
end
|
62
62
|
end
|
data/spec/ie/rr_spec.rb
CHANGED
@@ -1,43 +1,43 @@
|
|
1
|
-
require
|
2
|
-
require_relative
|
1
|
+
require 'spec_helper'
|
2
|
+
require_relative 'shared_examples_for_to_remove_all_masks'
|
3
3
|
|
4
4
|
describe BrDocuments::IE::RR do
|
5
|
-
describe
|
6
|
-
it
|
7
|
-
ie = described_class.new(
|
8
|
-
expect(ie.formatted).to eq
|
5
|
+
describe '#formatted' do
|
6
|
+
it 'returns a formatted ie' do
|
7
|
+
ie = described_class.new('123456789')
|
8
|
+
expect(ie.formatted).to eq '12345678-9'
|
9
9
|
end
|
10
10
|
end
|
11
11
|
|
12
|
-
describe
|
13
|
-
it
|
14
|
-
[
|
12
|
+
describe '#valid?' do
|
13
|
+
it 'is invalid with malformed number' do
|
14
|
+
['24.410.109-5', '2456128-32', '24AB0559-6'].each do |number|
|
15
15
|
ie = described_class.new(number)
|
16
16
|
expect(ie).to_not be_valid
|
17
17
|
end
|
18
18
|
end
|
19
19
|
|
20
|
-
it
|
21
|
-
[
|
20
|
+
it 'is invalid with length different to 9' do
|
21
|
+
['1234567', '123456789'].each do |number|
|
22
22
|
ie = described_class.new(number)
|
23
23
|
expect(ie).to_not be_valid
|
24
24
|
end
|
25
25
|
end
|
26
26
|
|
27
|
-
it
|
28
|
-
[
|
27
|
+
it 'is invalid with invalid check number' do
|
28
|
+
['242131962', '247318099'].each do |number|
|
29
29
|
ie = described_class.new(number)
|
30
30
|
expect(ie).to_not be_valid
|
31
31
|
end
|
32
32
|
end
|
33
33
|
|
34
|
-
it
|
35
|
-
[
|
34
|
+
it 'is valid with valid number' do
|
35
|
+
['241432573', '240886456'].each do |number|
|
36
36
|
ie = described_class.new(number)
|
37
37
|
expect(ie).to be_valid
|
38
38
|
end
|
39
39
|
end
|
40
40
|
|
41
|
-
include_examples
|
41
|
+
include_examples 'for to remove all masks', '24088645-6'
|
42
42
|
end
|
43
43
|
end
|
data/spec/ie/rs_spec.rb
CHANGED
@@ -1,41 +1,41 @@
|
|
1
|
-
require
|
2
|
-
require_relative
|
1
|
+
require 'spec_helper'
|
2
|
+
require_relative 'shared_examples_for_to_remove_all_masks'
|
3
3
|
|
4
4
|
describe BrDocuments::IE::RS do
|
5
|
-
describe
|
6
|
-
it
|
7
|
-
ie = described_class.new(
|
8
|
-
expect(ie.formatted).to eq
|
5
|
+
describe '#formatted' do
|
6
|
+
it 'returns a formatted ie' do
|
7
|
+
ie = described_class.new('1234567890')
|
8
|
+
expect(ie.formatted).to eq '123/4567890'
|
9
9
|
end
|
10
10
|
end
|
11
11
|
|
12
|
-
describe
|
13
|
-
it
|
14
|
-
ie = described_class.new(
|
12
|
+
describe '#valid?' do
|
13
|
+
it 'is invalid with malformed number' do
|
14
|
+
ie = described_class.new('17/70169293')
|
15
15
|
expect(ie).to_not be_valid
|
16
16
|
end
|
17
17
|
|
18
|
-
it
|
19
|
-
[
|
18
|
+
it 'is invalid with length different to 10' do
|
19
|
+
['123456789', '12345678901'].each do |number|
|
20
20
|
ie = described_class.new(number)
|
21
21
|
expect(ie).to_not be_valid
|
22
22
|
end
|
23
23
|
end
|
24
24
|
|
25
|
-
it
|
26
|
-
[
|
25
|
+
it 'is invalid with invalid check number' do
|
26
|
+
['1770169292', '034/0112114'].each do |number|
|
27
27
|
ie = described_class.new(number)
|
28
28
|
expect(ie).to_not be_valid
|
29
29
|
end
|
30
30
|
end
|
31
31
|
|
32
|
-
it
|
33
|
-
[
|
32
|
+
it 'is valid with valid number' do
|
33
|
+
['1770169293', '034/0112115'].each do |number|
|
34
34
|
ie = described_class.new(number)
|
35
35
|
expect(ie).to be_valid
|
36
36
|
end
|
37
37
|
end
|
38
38
|
|
39
|
-
include_examples
|
39
|
+
include_examples 'for to remove all masks', '034/0112115'
|
40
40
|
end
|
41
41
|
end
|
data/spec/ie/sc_spec.rb
CHANGED
@@ -1,43 +1,43 @@
|
|
1
|
-
require
|
2
|
-
require_relative
|
1
|
+
require 'spec_helper'
|
2
|
+
require_relative 'shared_examples_for_to_remove_all_masks'
|
3
3
|
|
4
4
|
describe BrDocuments::IE::SC do
|
5
|
-
describe
|
6
|
-
it
|
7
|
-
ie = described_class.new(
|
8
|
-
expect(ie.formatted).to eq
|
5
|
+
describe '#formatted' do
|
6
|
+
it 'returns a formatted ie' do
|
7
|
+
ie = described_class.new('123456789')
|
8
|
+
expect(ie.formatted).to eq '123.456.789'
|
9
9
|
end
|
10
10
|
end
|
11
11
|
|
12
|
-
describe
|
13
|
-
it
|
14
|
-
[
|
12
|
+
describe '#valid?' do
|
13
|
+
it 'is invalid with malformed number' do
|
14
|
+
['253.66.7852', '25.4062.407', 'A12345678'].each do |number|
|
15
15
|
ie = described_class.new(number)
|
16
16
|
expect(ie).to_not be_valid
|
17
17
|
end
|
18
18
|
end
|
19
19
|
|
20
|
-
it
|
21
|
-
[
|
20
|
+
it 'is invalid with length different to 9' do
|
21
|
+
['1234567890', '12345678'].each do |number|
|
22
22
|
ie = described_class.new(number)
|
23
23
|
expect(ie).to_not be_valid
|
24
24
|
end
|
25
25
|
end
|
26
26
|
|
27
|
-
it
|
28
|
-
[
|
27
|
+
it 'is invalid with invalid check number' do
|
28
|
+
['253667853', '254.062.408'].each do |number|
|
29
29
|
ie = described_class.new(number)
|
30
30
|
expect(ie).to_not be_valid
|
31
31
|
end
|
32
32
|
end
|
33
33
|
|
34
|
-
it
|
35
|
-
[
|
34
|
+
it 'is valid with valid number' do
|
35
|
+
['253667852', '254.062.407'].each do |number|
|
36
36
|
ie = described_class.new(number)
|
37
37
|
expect(ie).to be_valid
|
38
38
|
end
|
39
39
|
end
|
40
40
|
|
41
|
-
include_examples
|
41
|
+
include_examples 'for to remove all masks', '254.062.407'
|
42
42
|
end
|
43
43
|
end
|
data/spec/ie/se_spec.rb
CHANGED
@@ -1,16 +1,16 @@
|
|
1
|
-
require
|
2
|
-
require_relative
|
3
|
-
require_relative
|
1
|
+
require 'spec_helper'
|
2
|
+
require_relative 'shared_examples_for_pattern1'
|
3
|
+
require_relative 'shared_examples_for_to_remove_all_masks'
|
4
4
|
|
5
5
|
describe BrDocuments::IE::SE do
|
6
|
-
describe
|
7
|
-
it
|
8
|
-
ie = described_class.new(
|
9
|
-
expect(ie.formatted).to eq
|
6
|
+
describe '#formatted' do
|
7
|
+
it 'returns a formatted ie' do
|
8
|
+
ie = described_class.new('123456789')
|
9
|
+
expect(ie.formatted).to eq '12345678-9'
|
10
10
|
end
|
11
11
|
end
|
12
12
|
|
13
|
-
it_behaves_like
|
13
|
+
it_behaves_like 'a pattern1', 'SE'
|
14
14
|
|
15
|
-
include_examples
|
15
|
+
include_examples 'for to remove all masks', '12345678-9'
|
16
16
|
end
|
@@ -1,30 +1,30 @@
|
|
1
|
-
require
|
1
|
+
require 'spec_helper'
|
2
2
|
|
3
|
-
shared_examples
|
4
|
-
describe BrDocuments::IE::Factory,
|
5
|
-
it
|
6
|
-
[
|
3
|
+
shared_examples 'a pattern1' do |uf|
|
4
|
+
describe BrDocuments::IE::Factory, '#valid?' do
|
5
|
+
it 'is invalid with malformed number' do
|
6
|
+
['1922212-21', '72.219.398-0', '63BA9943-8'].each do |number|
|
7
7
|
ie = described_class.create(uf, number)
|
8
8
|
expect(ie).to_not be_valid
|
9
9
|
end
|
10
10
|
end
|
11
11
|
|
12
|
-
it
|
13
|
-
[
|
12
|
+
it 'is invalid with length different to 9' do
|
13
|
+
['1234567', '12345678901'].each do |number|
|
14
14
|
ie = described_class.create(uf, number)
|
15
15
|
expect(ie).to_not be_valid
|
16
16
|
end
|
17
17
|
end
|
18
18
|
|
19
|
-
it
|
20
|
-
[
|
19
|
+
it 'is invalid with invalid check number' do
|
20
|
+
['226905727', '662637732'].each do |number|
|
21
21
|
ie = described_class.create(uf, number)
|
22
22
|
expect(ie).to_not be_valid
|
23
23
|
end
|
24
24
|
end
|
25
25
|
|
26
|
-
it
|
27
|
-
[
|
26
|
+
it 'is valid with valid number' do
|
27
|
+
['732766940', '665822081'].each do |number|
|
28
28
|
ie = described_class.create(uf, number)
|
29
29
|
expect(ie).to be_valid
|
30
30
|
end
|
@@ -1,15 +1,14 @@
|
|
1
|
-
require
|
1
|
+
require 'spec_helper'
|
2
2
|
|
3
|
-
shared_examples
|
4
|
-
describe
|
3
|
+
shared_examples 'for to remove all masks' do |valid_number_with_mask|
|
4
|
+
describe '#valid?' do
|
5
|
+
context 'when the number is valid' do
|
6
|
+
subject { described_class.new(valid_number_with_mask) }
|
5
7
|
|
6
|
-
|
7
|
-
subject { described_class.new(valid_number_with_mask) }
|
8
|
-
|
9
|
-
it "removes the mask" do
|
8
|
+
it 'removes the mask' do
|
10
9
|
expect(subject).to be_valid
|
11
10
|
|
12
|
-
only_numbers = valid_number_with_mask.gsub(/[\.\/-]/,
|
11
|
+
only_numbers = valid_number_with_mask.gsub(/[\.\/-]/, '')
|
13
12
|
expect(valid_number_with_mask).to eq only_numbers
|
14
13
|
end
|
15
14
|
end
|