Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Add rspec files, and the first two tests.

  • Loading branch information...
commit e8b72a74ec71cca12c45a2ce673cc88834e4c6eb 1 parent 473e7e9
@gravitystorm authored
View
1  .rspec
@@ -0,0 +1 @@
+--colour --drb
View
0  lib/tasks/.gitkeep
No changes.
View
1  lib/tasks/rspec_modifier.rake
@@ -0,0 +1 @@
+Rake::Task[:spec].clear_prerequisites
View
27 spec/factories/project_nodes.rb
@@ -0,0 +1,27 @@
+# == Schema Information
+#
+# Table name: project_nodes
+#
+# id :integer not null, primary key
+# project_id :integer not null
+# osm_id :integer(8) not null
+# version :integer not null
+# user_id :integer not null
+# tstamp :datetime not null
+# changeset_id :integer(8) not null
+# tags :hstore
+# created_at :datetime
+# updated_at :datetime
+# geom :spatial({:srid=
+#
+
+FactoryGirl.define do
+ factory :project_node do
+ project_id 1
+ osm_id 2
+ user_id 3
+ version 4
+ tstamp Time.now
+ changeset_id 5
+ end
+end
View
37 spec/models/project_node_spec.rb
@@ -0,0 +1,37 @@
+# == Schema Information
+#
+# Table name: project_nodes
+#
+# id :integer not null, primary key
+# project_id :integer not null
+# osm_id :integer(8) not null
+# version :integer not null
+# user_id :integer not null
+# tstamp :datetime not null
+# changeset_id :integer(8) not null
+# tags :hstore
+# created_at :datetime
+# updated_at :datetime
+# geom :spatial({:srid=
+#
+
+require 'spec_helper'
+
+describe ProjectNode do
+ describe "newly created" do
+ subject { FactoryGirl.create(:project_node) }
+
+ it "should have an osm_id" do
+ subject.osm_id.should eql(2)
+ end
+ end
+
+ describe "to be valid" do
+ subject { FactoryGirl.build(:project_node) }
+
+ it "must belong to a project" do
+ subject.project = nil
+ subject.should_not be_valid
+ end
+ end
+end
View
88 spec/spec_helper.rb
@@ -0,0 +1,88 @@
+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.
+
+ ENV["RAILS_ENV"] ||= 'test'
+
+ require File.expand_path("../../config/environment", __FILE__)
+ require 'rspec/rails'
+ require 'capybara/rspec'
+ require 'database_cleaner'
+
+ 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
+
+ # 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 = true
+
+ # Render views in controller tests
+ config.render_views
+
+ config.before(:suite) do
+ DatabaseCleaner.strategy = :transaction
+ DatabaseCleaner.clean_with(:truncation, except: %w(geometry_columns spatial_ref_sys))
+ 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.
+ FactoryGirl.reload
+
+ # Reload translations
+ I18n.reload!
+
+ # 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}
+end
+
+# --- Instructions ---
+# Sort the contents of this file into a Spork.prefork and a Spork.each_run
+# block.
+#
+# The Spork.prefork block is run only once when the spork server is started.
+# You typically want to place most of your (slow) initializer code in here, in
+# particular, require'ing any 3rd-party gems that you don't normally modify
+# during development.
+#
+# The Spork.each_run block is run each time you run your specs. In case you
+# need to load files that tend to change during development, require them here.
+# With Rails, your application modules are loaded automatically, so sometimes
+# this block can remain empty.
+#
+# Note: You can modify files loaded *from* the Spork.each_run block without
+# restarting the spork server. However, this file itself will not be reloaded,
+# so if you change any of the code inside the each_run block, you still need to
+# restart the server. In general, if you have non-trivial code in this file,
+# it's advisable to move it into a separate file so you can easily edit it
+# without restarting spork. (For example, with RSpec, you could move
+# non-trivial code into a file spec/support/my_helper.rb, making sure that the
+# spec/support/* files are require'd from inside the each_run block.)
+#
+# Any code that is left outside the two blocks will be run during preforking
+# *and* during each_run -- that's probably not what you want.
+#
+# These instructions should self-destruct in 10 seconds. If they don't, feel
+# free to delete them.
Please sign in to comment.
Something went wrong with that request. Please try again.