summaryrefslogtreecommitdiff
path: root/test/flake_id_test.exs
diff options
context:
space:
mode:
authorkaniini <nenolod@gmail.com>2019-01-25 04:59:06 +0000
committerkaniini <nenolod@gmail.com>2019-01-25 04:59:06 +0000
commit4df71cd88b2725f1838c2899b3078a74dbb0c33f (patch)
tree33da1ceebc81b01a0afabc324c37fefd1352711d /test/flake_id_test.exs
parent9bf1a4234da5125d27c21fb2d4212377348ec123 (diff)
parenta3ba72d97849ba12a5ea4008bd0b97e80bdd588b (diff)
downloadpleroma-4df71cd88b2725f1838c2899b3078a74dbb0c33f.tar.gz
pleroma-4df71cd88b2725f1838c2899b3078a74dbb0c33f.zip
Merge branch 'classic-flakeids' into 'develop'
Flake Ids for Users and Activities Closes #450 See merge request pleroma/pleroma!645
Diffstat (limited to 'test/flake_id_test.exs')
-rw-r--r--test/flake_id_test.exs41
1 files changed, 41 insertions, 0 deletions
diff --git a/test/flake_id_test.exs b/test/flake_id_test.exs
new file mode 100644
index 000000000..8e969fd1c
--- /dev/null
+++ b/test/flake_id_test.exs
@@ -0,0 +1,41 @@
+# Pleroma: A lightweight social networking server
+# Copyright © 2017-2019 Pleroma Authors <https://pleroma.social/>
+# SPDX-License-Identifier: AGPL-3.0-only
+
+defmodule Pleroma.FlakeIdTest do
+ use Pleroma.DataCase
+ import Kernel, except: [to_string: 1]
+ import Pleroma.FlakeId
+
+ describe "fake flakes (compatibility with older serial integers)" do
+ test "from_string/1" do
+ fake_flake = <<0::integer-size(64), 42::integer-size(64)>>
+ assert from_string("42") == fake_flake
+ end
+
+ test "zero or -1 is a null flake" do
+ fake_flake = <<0::integer-size(128)>>
+ assert from_string("0") == fake_flake
+ assert from_string("-1") == fake_flake
+ end
+
+ test "to_string/1" do
+ fake_flake = <<0::integer-size(64), 42::integer-size(64)>>
+ assert to_string(fake_flake) == "42"
+ end
+ end
+
+ test "ecto type behaviour" do
+ flake = <<0, 0, 1, 104, 80, 229, 2, 235, 140, 22, 69, 201, 53, 210, 0, 0>>
+ flake_s = "9eoozpwTul5mjSEDRI"
+
+ assert cast(flake) == {:ok, flake_s}
+ assert cast(flake_s) == {:ok, flake_s}
+
+ assert load(flake) == {:ok, flake_s}
+ assert load(flake_s) == {:ok, flake_s}
+
+ assert dump(flake_s) == {:ok, flake}
+ assert dump(flake) == {:ok, flake}
+ end
+end