# -*- encoding: utf-8 -*- require 'spec_helper' RSpec.describe Brcobranca::Remessa::Pagamento do let(:pagamento) do subject.class.new(valor: 199.9, data_vencimento: Date.parse('2015-06-25'), nosso_numero: 123, documento_sacado: '12345678901', nome_sacado: 'nome', endereco_sacado: 'endereco', bairro_sacado: 'bairro', cep_sacado: '12345678', cidade_sacado: 'cidade', uf_sacado: 'SP') end context 'validacoes' do it 'deve ser invalido se nao possuir nosso numero' do pagamento.nosso_numero = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Nosso numero não pode estar em branco.') end it 'deve ser invalido se nao possuir data de vencimento' do pagamento.data_vencimento = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Data vencimento não pode estar em branco.') end it 'deve ser invalido se nao possuir valor do documento' do pagamento.valor = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Valor não pode estar em branco.') end it 'deve ser invalido se nao possuir documento do sacado' do pagamento.documento_sacado = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Documento sacado não pode estar em branco.') end it 'deve ser invalido se nao possuir nome do sacado' do pagamento.nome_sacado = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Nome sacado não pode estar em branco.') end it 'deve ser invalido se nao possuir endereco do sacado' do pagamento.endereco_sacado = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Endereco sacado não pode estar em branco.') end it 'deve ser invalido se nao possuir cidade do sacado' do pagamento.cidade_sacado = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Cidade sacado não pode estar em branco.') end it 'deve ser invalido se nao possuir UF do sacado' do pagamento.uf_sacado = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Uf sacado não pode estar em branco.') end context '@cep' do it 'deve ser invalido se nao possuir CEP' do pagamento.cep_sacado = nil expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Cep sacado não pode estar em branco.') end it 'deve ser invalido se CEP nao tiver 8 digitos' do pagamento.cep_sacado = '123456789' expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Cep sacado deve ter 8 dígitos.') end end it 'deve ser invalido se codigo do desconto tiver mais de 1 digito' do pagamento.cod_desconto = '123' expect(pagamento.invalid?).to be true expect(pagamento.errors.full_messages).to include('Cod desconto deve ter 1 dígito.') end end context 'informacoes padrao' do it 'data de emissao padrao deve ser o dia corrente' do expect(pagamento.data_emissao).to eq Date.today end it 'nome do avalista padrao deve ser vazio' do expect(pagamento.nome_avalista).to eq '' end it 'valor da mora padrao deve ser zero' do expect(pagamento.valor_mora).to eq 0.0 end it 'valor do desconto padrao deve ser zero' do expect(pagamento.valor_desconto).to eq 0.0 end it 'valor do IOF padrao deve ser zero' do expect(pagamento.valor_iof).to eq 0.0 end it 'valor do abatimento padrao deve ser zero' do expect(pagamento.valor_abatimento).to eq 0.0 end end context 'formatacoes dos valores' do context 'formata data do desconto' do it 'formata data limite do desconto de acordo com o formato passado' do pagamento.data_desconto = Date.parse('2015-06-25') # formato padrao: DDMMAA expect(pagamento.formata_data_desconto).to eq '250615' # outro formato expect(pagamento.formata_data_desconto('%d%m%Y')).to eq '25062015' end it 'retorna zeros se a data estiver vazia' do pagamento.data_desconto = nil expect(pagamento.formata_data_desconto).to eq '000000' end end it 'formata valor com o numero de posicoes passadas' do # padrao com 13 posicoes expect(pagamento.formata_valor).to eq '0000000019990' # formata com o numero passado expect(pagamento.formata_valor(8)).to eq '00019990' end it 'formata valor de mora com o numero de posicoes passadas' do # padrao com 13 posicoes pagamento.valor_mora = 9.0 expect(pagamento.formata_valor_mora).to eq '0000000000900' end it 'formata valor de desconto com o numero de posicoes passadas' do # padrao com 13 posicoes pagamento.valor_desconto = 129.0 expect(pagamento.formata_valor_desconto).to eq '0000000012900' # formata com o numero passado expect(pagamento.formata_valor_desconto(5)).to eq '12900' end it 'formata valor do IOF com o numero de posicoes passadas' do # padrao com 13 posicoes pagamento.valor_iof = 1.84 expect(pagamento.formata_valor_iof).to eq '0000000000184' # formata com o numero passado expect(pagamento.formata_valor_iof(15)).to eq '000000000000184' end it 'formata valor do abatimento com o numero de posicoes passadas' do # padrao com 13 posicoes pagamento.valor_abatimento = 34.9 expect(pagamento.formata_valor_abatimento).to eq '0000000003490' # formata com o numero passado expect(pagamento.formata_valor_abatimento(10)).to eq '0000003490' end context 'identificacao sacado' do it 'verifica a identificacao do sacado (pessoa fisica ou juridica)' do # pessoa fisica expect(pagamento.identificacao_sacado).to eq '01' # pessoa juridica pagamento.documento_sacado = '123456789101112' expect(pagamento.identificacao_sacado).to eq '02' pagamento.documento_sacado = '123456789101112' expect(pagamento.identificacao_sacado(false)).to eq '2' end end context 'identificacao avalista' do it 'verifica a identificacao do avalista (pessoa fisica ou juridica)' do # pessoa fisica pagamento.documento_avalista = '12345678901' expect(pagamento.identificacao_avalista).to eq '01' # pessoa juridica pagamento.documento_avalista = '123456789101112' expect(pagamento.identificacao_avalista).to eq '02' end it 'formata a identificacao com o numero de caracteres informados' do pagamento.documento_avalista = '12345678901' expect(pagamento.identificacao_avalista(false)).to eq '1' end end end end