私はcapybaraでテストする必要がある非同期javascript関数を持っています。テストでjs: true
オプションを使用してconfig.use_transactional_fixtures = false
に設定してからdatabase_cleaner
を投げてもらう必要があることを理解していますが、それでも動作させることはできません。Capybara with Javascript(Rspec、Spork、FactoryGirl to Boot)
cart_spec
は、カートに商品を追加して購入するプロセス全体を実行します(かなり深くネストされています)。
checkout.html.erb
は、stripe
ライブラリを使用してクレジットカードを処理します。それは私がテストする必要があるjavascriptの機能を持っています。
js: true
オプションでテストを実行すると、スポーツがデータベースに保存されていないことを示すsports_url
に「カートに入れる」というテストの失敗が表示されます。
js: true
オプションを指定せずにテストを実行すると、すべてのテストは、it "should warn user that cc number is invalid" do
を除いてパスされます。これは、javascriptが存在するためです。
私はspork
を実行していて、サーバーを再起動しようとしました。
編集
問題は、私のsports_url
がwww.example.com/sportsに向けられているので、私のテストは、ドメインwww.example.comで実行されていることです。私は新しい質問hereを尋ねました。私がsports_path
でそれにアクセスすると、それは素晴らしい作品です。ここで
は、ファイルは次のとおりです。
cart_spec:
require "spec_helper"
describe "Cart" do
before do
@user = FactoryGirl.create(:user)
@cart = @user.carts.create!
end
describe "using stripe" do
before do
@sport = FactoryGirl.create(:sport)
end
describe "user adds sport to cart", js: true do
before do
visit sports_url
click_link "Add to Cart"
end
it "should be checkout page" do
page.should have_content("Total")
end
describe "user clicks checkout" do
before do
click_button "Checkout"
end
it "should redirect user to sign in form" do
page.should have_selector('h2', text: "Sign in")
end
describe "user logs on" do
before do
fill_in "Email", with: @user.email
fill_in "Password", with: @user.password
click_button "Sign in"
end
it "should be on checkout page" do
page.should have_selector('h2', text: "Checkout")
end
describe "user fills in form" do
context "with invalid cc number" do
before do
fill_in "card-number", with: 42
click_button "Submit Payment"
end
it "should warn user that cc number is invalid" do
page.should have_content("Your card number is invalid")
end
end
end
end
end
end
end
describe "GET /carts/checkout" do
subject { @cart }
it { should respond_to(:paypal_url) }
it { should respond_to(:apply_discount) }
it "paypal_url contains notification" do
@cart.paypal_url(root_url, payment_notifications_url).should include("¬ify_url=http%3A%2F%2Fwww.example.com%2Fpayment_notifications")
end
it "paypal_url contains invoice id" do
@cart.paypal_url(root_url, payment_notifications_url).should match /&invoice=\d+&/
end
it "paypal_url contains return url" do
@cart.paypal_url(root_url, payment_notifications_url).should include("&return=http%3A%2F%2Fwww.example.com")
end
end
describe "GET /carts/discount" do
it "should apply discount to all line items" do
@cart.line_items.build(:unit_price => 48)
@cart.apply_discount
@cart.line_items.each do |lineItem|
lineItem.unit_price.should == 9.99
end
end
end
end
checkout.html.erb:
<h2>Checkout</h2>
<span class="payment-errors"></span>
<form action="" method="POST" id="payment-form">
<div class="form-row">
<label>Card Number</label>
<input type="text" size="20" autocomplete="off" id ="card-number" class="card-number"/>
</div>
<div class="form-row">
<label>CVC</label>
<input type="text" size="4" autocomplete="off" class="card-cvc"/>
</div>
<div class="form-row">
<label>Expiration (MM/YYYY)</label>
<input type="text" size="2" class="card-expiry-month"/>
<span>/</span>
<input type="text" size="4" class="card-expiry-year"/>
</div>
<button type="submit" class="submit-button">Submit Payment</button>
</form>
<script type="text/javascript" src="https://js.stripe.com/v1/"></script>
<script type="text/javascript">
Stripe.setPublishableKey('pk_xIm00GVAKVLMWmfeR2J8GlmeHcyhL');
$(document).ready(function() {
$("#payment-form").submit(function(event) {
// disable the submit button to prevent repeated clicks
$('.submit-button').attr("disabled", "disabled");
Stripe.createToken({
number: $('.card-number').val(),
cvc: $('.card-cvc').val(),
exp_month: $('.card-expiry-month').val(),
exp_year: $('.card-expiry-year').val()
}, stripeResponseHandler);
// prevent the form from submitting with the default action
return false;
});
});
function stripeResponseHandler(status, response) {
if (response.error) {
$('.submit-button').removeAttr("disabled");
//show the errors on the form
$(".payment-errors").html(response.error.message);
} else {
var form$ = $("#payment-form");
// token contains id, last4, and card type
var token = response['id'];
// insert the token into the form so it gets submitted to the server
form$.append("<input type='hidden' name='stripeToken' value='" + token + "'/>");
// and submit
form$.get(0).submit();
}
}
</script>
spec_helper:
require 'rubygems'
require 'spork'
Spork.prefork do
# Loading more in this block will cause your tests to run faster. However,
# if you change any configuration or code from libraries loaded here, you'll
# need to restart spork for it take effect.
# This file is copied to spec/ when you run 'rails generate rspec:install'
ENV["RAILS_ENV"] ||= 'test'
require File.expand_path("../../config/environment", __FILE__)
require 'rspec/rails'
require 'rspec/autorun'
# Requires supporting ruby files with custom matchers and macros, etc,
# in spec/support/ and its subdirectories.
Dir[Rails.root.join("spec/support/**/*.rb")].each {|f| require f}
RSpec.configure do |config|
# == Mock Framework
#
# If you prefer to use mocha, flexmock or RR, uncomment the appropriate line:
#
# config.mock_with :mocha
# config.mock_with :flexmock
# config.mock_with :rr
config.mock_with :rspec
# Remove this line if you're not using ActiveRecord or ActiveRecord fixtures
config.fixture_path = "#{::Rails.root}/spec/fixtures"
# If you're not using ActiveRecord, or you'd prefer not to run each of your
# examples within a transaction, remove the following line or assign false
# instead of true.
config.use_transactional_fixtures = false
# If true, the base class of anonymous controllers will be inferred
# automatically. This will be the default behavior in future versions of
# rspec-rails.
config.infer_base_class_for_anonymous_controllers = false
config.before(:suite) do
DatabaseCleaner.strategy = :truncation
end
config.before(:each) do
DatabaseCleaner.start
end
config.after(:each) do
DatabaseCleaner.clean
end
end
end
Spork.each_run do
# This code will be run each time you run your specs.
end
こんにちは、私はカピバラrspecを使用して、偽のデータでpaypal accocuntで私のウェブサイトをテストする方法を知っていません、あなたは私を助けてください、私は明日までに完了する必要があります.. –
あなたは何をしていますか? –
あなたの返事をありがとう、私は私の次のステップであるpaypal(テスト)に私のウェブサイトからお金の取引に立ち往生している?できるだけ早く返信してください... –