diff options
Diffstat (limited to 'test')
| -rw-r--r-- | test/factories.rb | 5 | ||||
| -rw-r--r-- | test/functional/v1/services_controller_test.rb | 6 | ||||
| -rw-r--r-- | test/integration/browser/account_test.rb | 27 | ||||
| -rw-r--r-- | test/integration/browser/session_test.rb | 20 | ||||
| -rw-r--r-- | test/support/browser_integration_test.rb | 15 | ||||
| -rw-r--r-- | test/unit/account_test.rb | 2 | 
6 files changed, 43 insertions, 32 deletions
| diff --git a/test/factories.rb b/test/factories.rb index ac9333c..bebda5c 100644 --- a/test/factories.rb +++ b/test/factories.rb @@ -22,6 +22,11 @@ FactoryGirl.define do          admin.stubs(:is_admin?).returns(true)        end      end + +    factory :premium_user do +      effective_service_level_code 2 +    end +    end    factory :token do diff --git a/test/functional/v1/services_controller_test.rb b/test/functional/v1/services_controller_test.rb index e4058c0..cde7d9f 100644 --- a/test/functional/v1/services_controller_test.rb +++ b/test/functional/v1/services_controller_test.rb @@ -21,10 +21,8 @@ class V1::ServicesControllerTest < ActionController::TestCase    test "user can see their service info" do      login      get :show, format: :json -    assert_json_response name: 'free', -      eip_rate_limit: true, -      description: 'free account, with rate limited VPN', -      storage: 100 +    default_level = APP_CONFIG[:default_service_level] +    assert_json_response APP_CONFIG[:service_levels][default_level]    end  end diff --git a/test/integration/browser/account_test.rb b/test/integration/browser/account_test.rb index 4e11520..491a9e1 100644 --- a/test/integration/browser/account_test.rb +++ b/test/integration/browser/account_test.rb @@ -6,7 +6,7 @@ class AccountTest < BrowserIntegrationTest      Identity.destroy_all_disabled    end -  test "normal account workflow" do +  test "signup successfully" do      username, password = submit_signup      assert page.has_content?("Welcome #{username}")      click_on 'Logout' @@ -16,6 +16,12 @@ class AccountTest < BrowserIntegrationTest      user.account.destroy    end +  test "signup with username ending in dot json" do +    username = Faker::Internet.user_name + '.json' +    submit_signup username +    assert page.has_content?("Welcome #{username}") +  end +    test "successful login" do      username, password = submit_signup      click_on 'Logout' @@ -51,7 +57,7 @@ class AccountTest < BrowserIntegrationTest    end    test "default user actions" do -    username, password = submit_signup +    login      click_on "Account Settings"      assert page.has_content? I18n.t('destroy_my_account')      assert page.has_no_css? '#update_login_and_password' @@ -59,8 +65,8 @@ class AccountTest < BrowserIntegrationTest    end    test "default admin actions" do -    username, password = submit_signup -    with_config admins: [username] do +    login +    with_config admins: [@user.login] do        click_on "Account Settings"        assert page.has_content? I18n.t('destroy_my_account')        assert page.has_no_css? '#update_login_and_password' @@ -70,7 +76,7 @@ class AccountTest < BrowserIntegrationTest    test "change password" do      with_config user_actions: ['change_password'] do -      username, password = submit_signup +      login        click_on "Account Settings"        within('#update_login_and_password') do          fill_in 'Password', with: "other password" @@ -78,16 +84,15 @@ class AccountTest < BrowserIntegrationTest          click_on 'Save'        end        click_on 'Logout' -      attempt_login(username, "other password") -      assert page.has_content?("Welcome #{username}") -      User.find_by_login(username).account.destroy +      attempt_login(@user.login, "other password") +      assert page.has_content?("Welcome #{@user.login}")      end    end    test "change pgp key" do      with_config user_actions: ['change_pgp_key'] do        pgp_key = FactoryGirl.build :pgp_key -      username, password = submit_signup +      login        click_on "Account Settings"        within('#update_pgp_key') do          fill_in 'Public key', with: pgp_key @@ -97,9 +102,7 @@ class AccountTest < BrowserIntegrationTest        # at some point we're done:        page.assert_no_selector 'input[value="Saving..."]'        assert page.has_field? 'Public key', with: pgp_key.to_s -      user = User.find_by_login(username) -      assert_equal pgp_key, user.public_key -      user.account.destroy +      assert_equal pgp_key, @user.reload.public_key      end    end diff --git a/test/integration/browser/session_test.rb b/test/integration/browser/session_test.rb index 3a41b3a..fb20847 100644 --- a/test/integration/browser/session_test.rb +++ b/test/integration/browser/session_test.rb @@ -2,26 +2,16 @@ require 'test_helper'  class SessionTest < BrowserIntegrationTest -  setup do -    @username, password = submit_signup -  end - -  teardown do -    user = User.find_by_login(@username) -    id = user.identity -    id.destroy -    user.destroy -  end -    test "valid session" do -    assert page.has_content?("Welcome #{@username}") +    login +    assert page.has_content?("Logout")    end    test "expired session" do -    assert page.has_content?("Welcome #{@username}") -    pretend_now_is(Time.now + 40.minutes) do +    login +    pretend_now_is(Time.now + 80.minutes) do        visit '/' -      assert page.has_no_content?("Welcome #{@username}") +      assert page.has_content?("Log In")      end    end  end diff --git a/test/support/browser_integration_test.rb b/test/support/browser_integration_test.rb index 9cae8cb..1c872ff 100644 --- a/test/support/browser_integration_test.rb +++ b/test/support/browser_integration_test.rb @@ -53,6 +53,21 @@ class BrowserIntegrationTest < ActionDispatch::IntegrationTest      return username, password    end +  # currently this only works for tests with poltergeist. +  def login(user = nil) +    @user ||= user ||= FactoryGirl.create(:user) +    token = Token.create user_id: user.id +    page.driver.add_header "Authorization", %Q(Token token="#{token}") +    visit '/' +  end + +  teardown do +    if @user && @user.reload +      Identity.destroy_all_for @user +      @user.destroy +    end +  end +    add_teardown_hook do |testcase|      unless testcase.passed?        testcase.save_state diff --git a/test/unit/account_test.rb b/test/unit/account_test.rb index 4fb3c3d..b2bfe27 100644 --- a/test/unit/account_test.rb +++ b/test/unit/account_test.rb @@ -8,7 +8,7 @@ class AccountTest < ActiveSupport::TestCase    test "create a new account" do      user = Account.create(FactoryGirl.attributes_for(:user)) -    assert user.valid? +    assert user.valid?, "unexpected errors: #{user.errors.inspect}"      assert user.persisted?      assert id = user.identity      assert_equal user.email_address, id.address | 
