Browse files

série de ajustes e melhorias

  • Loading branch information...
1 parent 29cd2b4 commit d9902efe276bb70c3e0ac4ee29b7023053f195b8 @guinascimento committed Apr 29, 2012
Showing with 346 additions and 219 deletions.
  1. 0 Gemfile
  2. +3 −0 Gemfile.lock
  3. 0 LICENSE
  4. +9 −3 README.markdown
  5. +1 −24 Rakefile
  6. +1 −1 VERSION
  7. +31 −62 lib/moip.rb
  8. +62 −0 lib/moip/client.rb
  9. +20 −5 lib/{ → moip}/direct_payment.rb
  10. +21 −65 moip.gemspec
  11. +198 −59 spec/moip_spec.rb
View
0 Gemfile 100644 → 100755
File mode changed.
View
3 Gemfile.lock 100644 → 100755
@@ -28,5 +28,8 @@ PLATFORMS
ruby
DEPENDENCIES
+ activesupport (>= 2.3.2)
+ httparty (~> 0.6.1)
moip!
+ nokogiri (~> 1.4.3)
rspec (~> 2.1.0)
View
0 LICENSE 100644 → 100755
File mode changed.
View
12 README.markdown 100644 → 100755
@@ -65,13 +65,19 @@ Após realizar os testes na SandBox, você poderá fazer a mudança para o ambie
###Checkout
def checkout
- response = MoIP.checkout(boleto)
+ response = MoIP::Client.checkout(boleto)
# exibe o boleto para impressão
- redirect_to MoIP.moip_page(response["Token"])
+ redirect_to MoIP::Client.moip_page(response["Token"])
end
-### Futuras implementações
+###Erros
+
+ - MoIP::MissingPaymentTypeError - Quando falta a razão do pagamento na requisição.
+ - MoIP::MissingPayerError - Quando falta as informações do pagador na requisição.
+ - MoIP::WebServerResponseError - Quando há algum erro ao se enviar a solicitação ao servidor. Normalmente a razão do erro vem como resposta da mensagem.
+
+## Futuras implementações
* Pagamento Simples
* Pagamento Recorrente
View
25 Rakefile 100644 → 100755
@@ -2,33 +2,10 @@
require 'rubygems'
require 'rake'
-begin
- require 'jeweler'
- Jeweler::Tasks.new do |gem|
- gem.name = "moip"
- gem.summary = "Gem para utilização da API MoIP"
- gem.description = "Gem para utilização da API MoIP"
- gem.email = "guilherme.ruby@gmail.com"
- gem.homepage = "http://github.com/guinascimento/moip"
- gem.authors = ["Guilherme Nascimento"]
- gem.add_development_dependency "rspec", "~> 2.1.0"
- gem.add_dependency "nokogiri", "~> 1.4.3"
- gem.add_dependency "httparty", "~> 0.8.1"
- gem.add_dependency "activesupport", '>= 2.3.2'
- end
- Jeweler::GemcutterTasks.new
-rescue LoadError
- puts "Jeweler (or a dependency) not available. Install it with: gem install jeweler"
-end
-
require 'rspec/core/rake_task'
-desc "Run all examples"
-RSpec::Core::RakeTask.new
-
-task :spec => :check_dependencies
-
task :default => :spec
+RSpec::Core::RakeTask.new
require 'rake/rdoctask'
Rake::RDocTask.new do |rdoc|
View
2 VERSION 100644 → 100755
@@ -1 +1 @@
-2.1.2
+1.0.1
View
93 lib/moip.rb 100644 → 100755
@@ -1,78 +1,47 @@
# encoding: utf-8
require "rubygems"
require 'active_support/core_ext/module/attribute_accessors'
-require 'httparty'
-require "nokogiri"
-
-require "direct_payment"
+require 'active_support/deprecation'
module MoIP
- include HTTParty
-
- # URI para acessar o serviço
- mattr_accessor :uri
- @@uri = 'https://www.moip.com.br'
-
- # Token de autenticação
- mattr_accessor :token
-
- # Chave de acesso ao serviço
- mattr_accessor :key
-
- def self.setup
- yield self
- end
+ autoload :DirectPayment, 'moip/direct_payment'
+ autoload :Client, 'moip/client'
- # Status de retorno
- STATUS = { 1 => "authorized", 2 => "started", 3 => "printed", 4 => "completed", 5 => "canceled", 6 => "analysing" }
+ # URI para acessar o serviço
+ mattr_accessor :uri
+ @@uri = 'https://www.moip.com.br'
- base_uri "#{self.uri}/ws/alpha"
- basic_auth self.token, self.key
+ # Token de autenticação
+ mattr_accessor :token
- class << self
- # Envia uma instrução para pagamento único
- def checkout(attributes = {})
- full_data = peform_action!(:post, 'EnviarInstrucao/Unica', :body => DirectPayment.body(attributes))
+ # Chave de acesso ao serviço
+ mattr_accessor :key
- get_response!(full_data["EnviarInstrucaoUnicaResponse"]["Resposta"])
- end
+ def self.setup
+ yield self
+ end
- # Consulta dos dados das autorizações e pagamentos associados à Instrução
- def query(token)
- full_data = peform_action!(:get, "ConsultarInstrucao/#{token}")
+ STATUS = {1 => "authorized", 2 => "started", 3 => "printed", 4 => "completed", 5 => "canceled", 6 => "analysing"}
- get_response!(full_data["ConsultarTokenResponse"]["RespostaConsultar"])
- end
-
- # Retorna a URL de acesso ao MoIP
- def moip_page(token)
- raise(StandardError, "É necessário informar um token para retornar os dados da transação") if token.nil?
- "#{self.uri}/Instrucao.do?token=#{token}"
- end
-
- # Monta o NASP
- def notification(params)
- notification = {}
- notification[:transaction_id] = params["id_transacao"]
- notification[:amount] = params["valor"]
- notification[:status] = STATUS[params["status_pagamento"].to_i]
- notification[:code] = params["cod_moip"]
- notification[:payment_type] = params["tipo_pagamento"]
- notification[:email] = params["email_consumidor"]
- notification
- end
+ class << self
+ def checkout(attributes = {})
+ ActiveSupport::Deprecation.warn("MoIP.checkout has been deprecated. Use MoIP::Client.checkout instead", caller)
+ MoIP::Client.checkout(attributes)
+ end
- private
+ def query(token)
+ ActiveSupport::Deprecation.warn("MoIP.query has been deprecated. Use MoIP::Client.query instead", caller)
+ MoIP::Client.query(token)
+ end
- def peform_action!(action_name, url, options = {})
- response = self.send(action_name, url, options)
- raise(StandardError, "Ocorreu um erro ao chamar o webservice") if response.nil?
- response
- end
+ def moip_page(token)
+ ActiveSupport::Deprecation.warn("MoIP.moip_page has been deprecated. use MoIP::Client.moip_page instead", caller)
+ MoIP::Client.moip_page(token)
+ end
- def get_response!(data)
- raise(StandardError, data["Erro"]) if data["Status"] == "Falha"
- data
- end
+ def notification(params)
+ ActiveSupport::Deprecation.warn("MoIP.notification has been deprecated. use MoIP::Client.notification instead", caller)
+ MoIP::Client.moip_page(token)
end
+ end
end
View
62 lib/moip/client.rb
@@ -0,0 +1,62 @@
+# encoding: utf-8
+require 'httparty'
+
+module MoIP
+ class WebServerResponseError < StandardError ; end
+ class MissingTokenError < StandardError ; end
+
+ class Client
+ include HTTParty
+
+ base_uri "#{MoIP.uri}/ws/alpha"
+ basic_auth MoIP.token, MoIP.key
+
+ class << self
+
+ # Envia uma instrução para pagamento único
+ def checkout(attributes = {})
+ full_data = peform_action!(:post, 'EnviarInstrucao/Unica', :body => DirectPayment.body(attributes))
+
+ get_response!(full_data["ns1:EnviarInstrucaoUnicaResponse"]["Resposta"])
+ end
+
+ # Consulta dos dados das autorizações e pagamentos associados à Instrução
+ def query(token)
+ full_data = peform_action!(:get, "ConsultarInstrucao/#{token}")
+
+ get_response!(full_data["ns1:ConsultarTokenResponse"]["RespostaConsultar"])
+ end
+
+ # Retorna a URL de acesso ao MoIP
+ def moip_page(token)
+ raise(MissingTokenError, "É necessário informar um token para retornar os dados da transação") if token.nil?
+ "#{MoIP.uri}/Instrucao.do?token=#{token}"
+ end
+
+ # Monta o NASP
+ def notification(params)
+ notification = {}
+ notification[:transaction_id] = params["id_transacao"]
+ notification[:amount] = params["valor"]
+ notification[:status] = MoIP::STATUS[params["status_pagamento"].to_i]
+ notification[:code] = params["cod_moip"]
+ notification[:payment_type] = params["tipo_pagamento"]
+ notification[:email] = params["email_consumidor"]
+ notification
+ end
+
+ private
+
+ def peform_action!(action_name, url, options = {})
+ response = self.send(action_name, url, options)
+ raise(WebServerResponseError, "Ocorreu um erro ao chamar o webservice") if response.nil?
+ response
+ end
+
+ def get_response!(data)
+ raise(WebServerResponseError, data["Erro"]) if data["Status"] == "Falha"
+ data
+ end
+ end
+ end
+end
View
25 lib/direct_payment.rb → lib/moip/direct_payment.rb 100644 → 100755
@@ -1,20 +1,29 @@
# encoding: utf-8
+require "nokogiri"
+
module MoIP
+ class MissingPaymentTypeError < StandardError ; end
+ class MissingPayerError < StandardError ; end
+
class DirectPayment
class << self
# Cria uma instrução de pagamento direto
def body(attributes = {})
+ raise(MissinPaymentTypeError, "É necessário informar a razão do pagamento") if attributes[:razao].nil?
+ raise(MissingPayerError, "É obrigatório passar as informações do pagador") if attributes[:pagador].nil?
+
builder = Nokogiri::XML::Builder.new(:encoding => "UTF-8") do |xml|
# Identificador do tipo de instrução
xml.EnviarInstrucao {
xml.InstrucaoUnica {
+
# Dados da transação
xml.Razao {
- xml.text "Pagamento"
+ xml.text attributes[:razao]
}
xml.Valores {
xml.Valor(:moeda => "BRL") {
@@ -43,7 +52,6 @@ def body(attributes = {})
xml.Instituicao {
xml.text attributes[:instituicao]
}
-
xml.CartaoCredito {
xml.Numero {
xml.text attributes[:numero]
@@ -81,7 +89,6 @@ def body(attributes = {})
}
# Dados do pagador
- raise(StandardError, "É obrigatório passar as informações do pagador") if attributes[:pagador].nil?
xml.Pagador {
xml.Nome { xml.text attributes[:pagador][:nome] }
xml.LoginMoIP { xml.text attributes[:pagador][:login_moip] }
@@ -117,15 +124,23 @@ def body(attributes = {})
}
}
end
-
+
+ if attributes[:url_retorno]
+ # URL de retorno
+ xml.URLRetorno {
+ xml.text attributes[:url_retorno]
+ }
+ end
+
}
}
end
+
builder.to_xml
end
end
end
-
+
end
View
86 moip.gemspec 100644 → 100755
@@ -1,71 +1,27 @@
-# Generated by jeweler
-# DO NOT EDIT THIS FILE DIRECTLY
-# Instead, edit Jeweler::Tasks in Rakefile, and run 'rake gemspec'
# -*- encoding: utf-8 -*-
-Gem::Specification.new do |s|
- s.name = %q{moip}
- s.version = "2.1.2"
+Gem::Specification.new do |gem|
+ gem.name = %q{moip}
+ gem.version = "1.0.6"
- s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
- s.authors = ["Guilherme Nascimento"]
- s.date = %q{2012-04-29}
- s.description = %q{Gem para utilização da API MoIP}
- s.email = %q{guilherme.ruby@gmail.com}
- s.extra_rdoc_files = [
- "LICENSE",
- "README.markdown"
- ]
- s.files = [
- ".document",
- "Gemfile",
- "Gemfile.lock",
- "LICENSE",
- "README.markdown",
- "Rakefile",
- "VERSION",
- "lib/direct_payment.rb",
- "lib/moip.rb",
- "moip.gemspec",
- "spec/moip_spec.rb"
- ]
- s.homepage = %q{http://github.com/guinascimento/moip}
- s.require_paths = ["lib"]
- s.rubygems_version = %q{1.3.6}
- s.summary = %q{Gem para utilização da API MoIP}
+ gem.authors = ["Guilherme Nascimento"]
+ gem.date = %q{2010-11-10}
+ gem.description = %q{Gem para utilização da API MoIP}
+ gem.email = %q{guilherme.ruby@gmail.com}
+ gem.summary = %q{Gem para utilização da API MoIP}
- if s.respond_to? :specification_version then
- current_version = Gem::Specification::CURRENT_SPECIFICATION_VERSION
- s.specification_version = 3
+ gem.files = `git ls-files`.split("\n")
+ gem.test_files = `git ls-files -- spec/*.rb`.split("\n")
- if Gem::Version.new(Gem::RubyGemsVersion) >= Gem::Version.new('1.2.0') then
- s.add_runtime_dependency(%q<moip>, [">= 0"])
- s.add_development_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_development_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_development_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_development_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_runtime_dependency(%q<nokogiri>, ["~> 1.4.3"])
- s.add_runtime_dependency(%q<httparty>, ["~> 0.8.1"])
- s.add_runtime_dependency(%q<activesupport>, [">= 2.3.2"])
- else
- s.add_dependency(%q<moip>, [">= 0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<nokogiri>, ["~> 1.4.3"])
- s.add_dependency(%q<httparty>, ["~> 0.8.1"])
- s.add_dependency(%q<activesupport>, [">= 2.3.2"])
- end
- else
- s.add_dependency(%q<moip>, [">= 0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<rspec>, ["~> 2.1.0"])
- s.add_dependency(%q<nokogiri>, ["~> 1.4.3"])
- s.add_dependency(%q<httparty>, ["~> 0.8.1"])
- s.add_dependency(%q<activesupport>, [">= 2.3.2"])
- end
-end
+ gem.homepage = %q{http://github.com/moiplabs/moip-ruby}
+ gem.require_paths = ["lib"]
+
+ gem.rdoc_options = ["--charset=UTF-8"]
+ gem.extra_rdoc_files = [ "LICENSE", "README.markdown"]
+ gem.add_development_dependency(%q<rspec>, ["~> 2.1.0"])
+
+ gem.add_runtime_dependency(%q<nokogiri>, ["~> 1.4.2"])
+ gem.add_runtime_dependency(%q<httparty>, ["~> 0.6.1"])
+ gem.add_runtime_dependency(%q<activesupport>, [">= 2.3.2"])
+end
View
257 spec/moip_spec.rb 100644 → 100755
@@ -1,6 +1,8 @@
# encoding: utf-8
require "moip"
+require "digest/sha1"
+
describe "Make payments with the MoIP API" do
before :all do
@@ -26,107 +28,233 @@
:cep => "70100-000",
:tel_fixo => "(61)3211-1221" }
- @billet = { :value => "8.90", :id_proprio => id, :forma => "BoletoBancario", :pagador => @pagador }
- @debit = { :value => "8.90", :id_proprio => id, :forma => "DebitoBancario", :instituicao => "BancoDoBrasil", :pagador => @pagador }
- @credit = { :value => "8.90", :id_proprio => id, :forma => "CartaoCredito", :instituicao => "AmericanExpress", :numero => "345678901234564", :expiracao => "08/11", :codigo_seguranca => "1234", :nome => "João Silva", :identidade => "134.277.017.00", :telefone => "(21)9208-0547", :data_nascimento => "25/10/1980", :parcelas => "2", :recebimento => "AVista", :pagador => @pagador }
+ @billet_without_razao = { :value => "8.90", :id_proprio => id,
+ :forma => "BoletoBancario", :pagador => @pagador}
+ @billet = { :value => "8.90", :id_proprio => id,
+ :forma => "BoletoBancario", :pagador => @pagador ,
+ :razao=> "Pagamento" }
+
+ @debit = { :value => "8.90", :id_proprio => id, :forma => "DebitoBancario",
+ :instituicao => "BancoDoBrasil", :pagador => @pagador,
+ :razao => "Pagamento"}
+
+ @credit = { :value => "8.90", :id_proprio => id, :forma => "CartaoCredito",
+ :instituicao => "AmericanExpress",:numero => "345678901234564",
+ :expiracao => "08/11", :codigo_seguranca => "1234",
+ :nome => "João Silva", :identidade => "134.277.017.00",
+ :telefone => "(21)9208-0547", :data_nascimento => "25/10/1980",
+ :parcelas => "2", :recebimento => "AVista",
+ :pagador => @pagador, :razao => "Pagamento"}
end
- context "make a billet checkout" do
- it "should have status Sucesso" do
- MoIP.stub!(:post).and_return("ns1:EnviarInstrucaoUnicaResponse"=>{ "Resposta"=>{ "ID"=>Time.now.strftime("%y%m%d%H%M%S"), "Status"=>"Sucesso", "Token" => "T2N0L0X8E0S71217U2H3W1T4F4S4G4K731D010V0S0V0S080M010E0Q082X2" }})
- response = MoIP.checkout(@billet)
- response["Status"].should == "Sucesso"
+ context "checkout" do
+ before(:each) do
+ MoIP::Client.stub!(:post).
+ and_return("ns1:EnviarInstrucaoUnicaResponse"=>
+ { "Resposta"=>
+ { "ID"=>Time.now.strftime("%y%m%d%H%M%S"),
+ "Status"=>"Sucesso",
+ "Token" => "T2N0L0X8E0S71217U2H3W1T4F4S4G4K731D010V0S0V0S080M010E0Q082X2"
+ }
+ })
end
- end
- context "make a debit checkout" do
- it "should have status Sucesso" do
- MoIP.stub!(:post).and_return("ns1:EnviarInstrucaoUnicaResponse"=>{ "Resposta"=>{ "ID"=>Time.now.strftime("%y%m%d%H%M%S"), "Status"=>"Sucesso", "Token" => "T2N0L0X8E0S71217U2H3W1T4F4S4G4K731D010V0S0V0S080M010E0Q082X2" }})
- response = MoIP.checkout(@debit)
- response["Status"].should == "Sucesso"
+ it "with old api should be deprecated" do
+ deprecations = collect_deprecations{ MoIP.checkout(@billet) }
+
+ deprecations.should_not be_empty
+ deprecations.any? {|w| w =~ /MoIP.checkout has been deprecated/ }.should be_true
end
- end
- context "make a debit checkout without pass a institution" do
- it "should have status Falha" do
- @incorrect_debit = { :value => "37.90", :id_proprio => id, :forma => "DebitoBancario", :pagador => @pagador }
- MoIP.stub!(:post).and_return("ns1:EnviarInstrucaoUnicaResponse"=>{ "Resposta"=>{"Status"=>"Falha", "Erro"=>"Pagamento direto não é possível com a instituição de pagamento enviada" }})
- lambda { MoIP.checkout(@incorrect_debit) }.should raise_error(StandardError, "Pagamento direto não é possível com a instituição de pagamento enviada")
+ context "when it is a billet checkout" do
+ it "should raise an exception when razao parameter is not passed" do
+ error = "É necessário informar a razão do pagamento"
+
+ lambda { MoIP::Client.checkout(@billet_without_razao) }.should
+ raise_error(MoIP::MissingPaymentTypeError,error)
+ end
+
+ it "should have status 'Sucesso'" do
+ response = MoIP::Client.checkout(@billet)
+ response["Status"].should == "Sucesso"
+ end
end
- end
- context "make a debit checkout without pass the payer informations" do
- it "should raise an exception" do
- @incorrect_debit = { :value => "37.90", :id_proprio => id, :forma => "DebitoBancario", :instituicao => "BancoDoBrasil" }
- lambda { MoIP.checkout(@incorrect_debit) }.should raise_error(StandardError, "É obrigatório passar as informações do pagador")
+ context "when it is a debit checkout" do
+ it "should have status 'Sucesso' with valid arguments" do
+ response = MoIP::Client.checkout(@debit)
+ response["Status"].should == "Sucesso"
+ end
+
+ it "should have status 'Falha' when a instituition is not passed as argument" do
+ @incorrect_debit = { :value => "37.90", :id_proprio => id,
+ :forma => "DebitoBancario", :pagador => @pagador,
+ :razao => "Pagamento"}
+
+ error = "Pagamento direto não é possível com a instituição de pagamento enviada"
+
+ MoIP::Client.stub!(:post)
+ .and_return("ns1:EnviarInstrucaoUnicaResponse"=>
+ { "Resposta"=>
+ {
+ "Status"=>"Falha",
+ "Erro"=>error
+ }
+ })
+ error = "Pagamento direto não é possível com a instituição de pagamento enviada"
+ lambda { MoIP::Client.checkout(@incorrect_debit) }.should
+ raise_error(MoIP::WebServerResponseError, error)
+ end
+
+ it "should raise an exception if payer informations were not passed" do
+ @incorrect_debit = { :value => "37.90", :id_proprio => id,
+ :forma => "DebitoBancario",
+ :instituicao => "BancoDoBrasil",
+ :razao => "Pagamento"
+ }
+
+ lambda { MoIP::Client.checkout(@incorrect_debit) }.should
+ raise_error(MoIP::MissingPayerError, "É obrigatório passar as informações do pagador")
+ end
end
- end
- context "make a credit card checkout" do
- it "should have status Sucesso" do
- MoIP.stub!(:post).and_return("ns1:EnviarInstrucaoUnicaResponse"=>{ "Resposta"=>{ "ID"=>Time.now.strftime("%y%m%d%H%M%S"), "Status"=>"Sucesso", "Token" => "T2N0L0X8E0S71217U2H3W1T4F4S4G4K731D010V0S0V0S080M010E0Q082X2" }})
- response = MoIP.checkout(@credit)
- response["Status"].should == "Sucesso"
+ context "when it is a credit card checkout" do
+ it "should have status 'Sucesso' with valid arguments" do
+ response = MoIP::Client.checkout(@credit)
+ response["Status"].should == "Sucesso"
+ end
+
+ it "should have status 'Falha' when the card informations were not passed as argument" do
+ @incorrect_credit = { :value => "8.90", :id_proprio => id,
+ :forma => "CartaoCredito", :pagador => @pagador,
+ :razao => "Pagamento"
+ }
+
+ error = "Pagamento direto não é possível com a instituição de pagamento enviada"
+ MoIP::Client.stub!(:post)
+ .and_return("ns1:EnviarInstrucaoUnicaResponse"=>
+ {
+ "Resposta"=>
+ {
+ "Status"=>"Falha",
+ "Erro"=>error
+ }
+ })
+
+ error = "Pagamento direto não é possível com a instituição de pagamento enviada"
+ lambda { MoIP::Client.checkout(@incorrect_credit) }.should
+ raise_error(MoIP::WebServerResponseError, error)
+ end
end
- end
- context "make a credit card checkout without pass card informations" do
- it "should have status Falha" do
- @incorrect_credit = { :value => "8.90", :id_proprio => id, :forma => "CartaoCredito", :pagador => @pagador }
- MoIP.stub!(:post).and_return("ns1:EnviarInstrucaoUnicaResponse"=>{ "Resposta"=>{"Status"=>"Falha", "Erro"=>"Pagamento direto não é possível com a instituição de pagamento enviada" }})
- lambda { MoIP.checkout(@incorrect_credit) }.should raise_error(StandardError, "Pagamento direto não é possível com a instituição de pagamento enviada")
+ context "in error scenario" do
+ it "should raise an exception if response is nil" do
+ MoIP::Client.stub!(:post).and_return(nil)
+ lambda { MoIP::Client.checkout(@billet) }.should
+ raise_error(StandardError,"Ocorreu um erro ao chamar o webservice")
+ end
+
+ it "should raise an exception if status is fail" do
+ MoIP::Client.stub!(:post)
+ .and_return("ns1:EnviarInstrucaoUnicaResponse"=>
+ { "Resposta"=>
+ {"Status"=>"Falha",
+ "Erro"=>"O status da resposta é Falha"
+ }
+ })
+
+ lambda { MoIP::Client.checkout(@billet) }.should raise_error(StandardError, "O status da resposta é Falha")
+ end
end
end
- context "in error scenario" do
- it "should raise an exception if response is nil" do
- MoIP.stub!(:post).and_return(nil)
- lambda { MoIP.checkout(@billet) }.should raise_error(StandardError, "Ocorreu um erro ao chamar o webservice")
+ context "query a transaction token" do
+ before(:each) do
+ MoIP::Client.stub!(:get)
+ .and_return("ns1:ConsultarTokenResponse"=>
+ { "RespostaConsultar"=>
+ {"Status"=>"Sucesso",
+ "ID"=>"201010291031001210000000046760"
+ }
+ })
end
- it "should raise an exception if status is fail" do
- MoIP.stub!(:post).and_return("ns1:EnviarInstrucaoUnicaResponse"=>{ "Resposta"=>{"Status"=>"Falha", "Erro"=>"O status da resposta é Falha" }})
- lambda { MoIP.checkout(@billet) }.should raise_error(StandardError, "O status da resposta é Falha")
+ it "with old api should be deprecated" do
+ deprecations = collect_deprecations{ MoIP.query(token) }
+
+ deprecations.should_not be_empty
+ deprecations.any? {|w| w =~ /MoIP.query has been deprecated/ }.should be_true
end
- end
- context "query a transaction token" do
it "should retrieve the transaction" do
- MoIP.stub!(:get).and_return("ns1:ConsultarTokenResponse"=>{ "RespostaConsultar"=>{"Status"=>"Sucesso", "ID"=>"201010291031001210000000046760" }})
- response = MoIP.query(token)
+ response = MoIP::Client.query(token)
response["Status"].should == "Sucesso"
end
- end
- context "query a transaction token in a error scenario" do
- it "should retrieve status Falha" do
- MoIP.stub!(:get).and_return("ns1:ConsultarTokenResponse"=>{ "RespostaConsultar"=>{"Status"=>"Falha", "Erro"=>"Instrução não encontrada", "ID"=>"201010291102522860000000046768"}})
- lambda { MoIP.query("000000000000000000000000000000000000000000000000000000000000") }.should raise_error(StandardError, "Instrução não encontrada")
+ context "in a error scenario" do
+ it "should retrieve status 'Falha'" do
+ MoIP::Client.stub!(:get)
+ .and_return("ns1:ConsultarTokenResponse"=>
+ { "RespostaConsultar"=>
+ {"Status"=>"Falha",
+ "Erro"=>"Instrução não encontrada",
+ "ID"=>"201010291102522860000000046768"
+ }
+ })
+ query = "000000000000000000000000000000000000000000000000000000000000"
+ lambda { MoIP::Client.query(query) }.should raise_error(StandardError, "Instrução não encontrada")
+ end
end
end
context "build the MoIP URL" do
+ it "with old api should be deprecated" do
+ deprecations = collect_deprecations{ MoIP.moip_page(token) }
+
+ deprecations.should_not be_empty
+ deprecations.any? {|w| w =~ /MoIP.moip_page has been deprecated/ }.should be_true
+ end
+
it "should build the correct URL" do
- MoIP.moip_page(token).should == "https://desenvolvedor.moip.com.br/sandbox/Instrucao.do?token=#{token}"
+ page = "https://desenvolvedor.moip.com.br/sandbox/Instrucao.do?token=#{token}"
+ MoIP::Client.moip_page(token).should == page
end
it "should raise an error if the token is not informed" do
- lambda { MoIP.moip_page("").should raise_error(ArgumentError, "É necessário informar um token para retornar os dados da transação") }
+ error = "É necessário informar um token para retornar os dados da transação"
+ lambda { MoIP::Client.moip_page("").should
+ raise_error(ArgumentError, error) }
end
it "should raise an error if nil is passed as the token" do
- lambda { MoIP.moip_page(nil).should raise_error(ArgumentError, "É necessário informar um token para retornar os dados da transação") }
+ error = "É necessário informar um token para retornar os dados da transação"
+ lambda { MoIP::Client.moip_page(nil).should
+ raise_error(ArgumentError, error) }
end
end
context "when receive notification" do
before(:each) do
- @params = { "id_transacao" => "Pag62", "valor" => "8.90", "status_pagamento" => "3", "cod_moip" => "001", "forma_pagamento" => "73", "tipo_pagamento" => "BoletoBancario", "email_consumidor" => "presidente@planalto.gov.br" }
+ @params = { "id_transacao" => "Pag62", "valor" => "8.90",
+ "status_pagamento" => "3", "cod_moip" => "001",
+ "forma_pagamento" => "73", "tipo_pagamento" => "BoletoBancario",
+ "email_consumidor" => "presidente@planalto.gov.br" }
+ end
+
+ it "with old api should be deprecated" do
+ deprecations = collect_deprecations{ MoIP.notification(@param) }
+
+ deprecations.should_not be_empty
+ deprecations.any? {|w| w =~ /MoIP.notification has been deprecated/ }.should be_true
end
it "should return a hash with the params extracted from NASP" do
- response = { :transaction_id => "Pag62", :amount => "8.90", :status => "printed", :code => "001", :payment_type => "BoletoBancario", :email => "presidente@planalto.gov.br" }
- MoIP.notification(@params).should == response
+ response = { :transaction_id => "Pag62", :amount => "8.90",
+ :status => "printed", :code => "001",
+ :payment_type => "BoletoBancario",
+ :email => "presidente@planalto.gov.br" }
+
+ MoIP::Client.notification(@params).should == response
end
it "should return valid status based on status code" do
@@ -147,4 +275,15 @@ def token
"T2X0Q1N021E0B2S9U1P0V3Y0G1F570Y2P4M0P000M0Z0F0J0G0U4N6C7W5T9"
end
+ def collect_deprecations
+ old_behavior = ActiveSupport::Deprecation.behavior
+ deprecations = []
+ ActiveSupport::Deprecation.behavior = Proc.new do |message, callstack|
+ deprecations << message
+ end
+ result = yield
+ deprecations
+ ensure
+ ActiveSupport::Deprecation.behavior = old_behavior
+ end
end

0 comments on commit d9902ef

Please sign in to comment.