summaryrefslogtreecommitdiff
path: root/test/integration/regression
diff options
context:
space:
mode:
authorAzul <azul@riseup.net>2017-03-20 11:16:21 +0100
committerAzul <azul@riseup.net>2017-03-20 11:16:21 +0100
commita741152e33f6a681113818418ad0f898f2d04697 (patch)
tree897a279db2be8dcebe77f45b84b8d9c500766a7d /test/integration/regression
parent15de288c3ca9bacc3d45675878ee7b8a2d9fc935 (diff)
fix: 404 for missing pages template - fixes #9
Diffstat (limited to 'test/integration/regression')
-rw-r--r--test/integration/regression/key_discovery_test.rb23
-rw-r--r--test/integration/regression/provider_info_test.rb20
2 files changed, 43 insertions, 0 deletions
diff --git a/test/integration/regression/key_discovery_test.rb b/test/integration/regression/key_discovery_test.rb
new file mode 100644
index 0000000..2a38a78
--- /dev/null
+++ b/test/integration/regression/key_discovery_test.rb
@@ -0,0 +1,23 @@
+require 'test_helper'
+
+# This is not really a browser test - key discovery is used from bitmask.
+# However we need to make sure to test the full rack stack to replicate
+# exception handling.
+class KeyDiscoveryTest < RackStackTest
+ include Capybara::DSL
+
+ setup do
+ # make sure we test the whole stack...
+ Capybara.current_driver = Capybara.javascript_driver
+ end
+
+ teardown do
+ # Revert Capybara.current_driver to Capybara.default_driver
+ Capybara.use_default_driver
+ end
+
+ def test_404_on_non_existing_user
+ visit '/key/asjkholifweatg'
+ assert_equal 404, status_code
+ end
+end
diff --git a/test/integration/regression/provider_info_test.rb b/test/integration/regression/provider_info_test.rb
new file mode 100644
index 0000000..2aaf6f6
--- /dev/null
+++ b/test/integration/regression/provider_info_test.rb
@@ -0,0 +1,20 @@
+require 'test_helper'
+
+class ProviderInfoTest < BrowserIntegrationTest
+
+ def test_404_on_missing_page
+ visit '/about'
+ assert_equal 404, status_code
+ end
+
+ def test_404_on_missing_language_page
+ visit '/de/about'
+ assert_equal 404, status_code
+ end
+
+ def test_404_en_fallback
+ visit '/de/bye'
+ assert_equal 200, status_code
+ end
+
+end