]> git.openstreetmap.org Git - rails.git/blobdiff - test/models/redaction_test.rb
Reorganise tests to match modern rails test layout
[rails.git] / test / models / redaction_test.rb
diff --git a/test/models/redaction_test.rb b/test/models/redaction_test.rb
new file mode 100644 (file)
index 0000000..61b64f2
--- /dev/null
@@ -0,0 +1,36 @@
+require 'test_helper'
+require 'osm'
+
+class RedactionTest < ActiveSupport::TestCase
+  api_fixtures
+  fixtures :redactions
+
+  def test_cannot_redact_current
+    n = current_nodes(:node_with_versions)
+    r = redactions(:example)
+    assert_equal(false, n.redacted?, "Expected node to not be redacted already.")
+    assert_raise(OSM::APICannotRedactError) do
+      n.redact!(r)
+    end
+  end
+
+  def test_cannot_redact_current_via_old
+    n = nodes(:node_with_versions_v4)
+    r = redactions(:example)
+    assert_equal(false, n.redacted?, "Expected node to not be redacted already.")
+    assert_raise(OSM::APICannotRedactError) do
+      n.redact!(r)
+    end
+  end
+
+  def test_can_redact_old
+    n = nodes(:node_with_versions_v3)
+    r = redactions(:example)
+    assert_equal(false, n.redacted?, "Expected node to not be redacted already.")
+    assert_nothing_raised(OSM::APICannotRedactError) do
+      n.redact!(r)
+    end
+    assert_equal(true, n.redacted?, "Expected node to be redacted after redact! call.")
+  end
+
+end