2017-12-27 00:03:47 +03:00
|
|
|
/+ new-hoon, tester
|
|
|
|
=, dct:new-hoon
|
|
|
|
=+ four=(from-list [[1 "one"] [2 "two"] [3 "three"] [4 "four"] ~])
|
|
|
|
=+ three=(from-list [[1 "one"] [2 "two"] [3 "three"] ~])
|
2018-03-10 04:31:44 +03:00
|
|
|
|_ _tester:tester
|
2017-12-27 00:03:47 +03:00
|
|
|
++ test-empty
|
2018-03-10 04:27:45 +03:00
|
|
|
(expect-eq (empty four) %.n)
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-size
|
2018-03-10 04:27:45 +03:00
|
|
|
(expect-eq (size four) 4)
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-member
|
2018-03-10 04:27:45 +03:00
|
|
|
(expect-eq (member four 4) %.y)
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-put-with
|
|
|
|
=+ ints=(from-list [["one" 1] ["two" 2] ["three" 3] ["four" 4] ~])
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(put-with ints "three" 2 add)
|
2017-12-27 00:03:47 +03:00
|
|
|
(from-list [["one" 1] ["two" 2] ["three" 5] ["four" 4] ~])
|
|
|
|
::
|
|
|
|
++ test-put-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(put-with-key four 4 "four" |=({a/@ud b/tape c/tape} (weld (scow %ud a) b)))
|
2017-12-27 00:03:47 +03:00
|
|
|
(from-list [[1 "one"] [2 "two"] [3 "three"] [4 "4four"] ~])
|
|
|
|
::
|
|
|
|
++ test-put-lookup-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ put-lookup-with-key four
|
2017-12-27 00:03:47 +03:00
|
|
|
4
|
2018-03-10 04:27:45 +03:00
|
|
|
:- "five"
|
|
|
|
|=({key/@ud old/tape new/tape} new)
|
2017-12-27 00:03:47 +03:00
|
|
|
:- `"four"
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 "one"] [2 "two"] [3 "three"] [4 "five"] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-delete
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(delete four 4)
|
2017-12-27 00:03:47 +03:00
|
|
|
three
|
|
|
|
::
|
|
|
|
++ test-adjust
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ adjust four
|
|
|
|
3
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/tape (weld "this" a))
|
|
|
|
(from-list [[1 "one"] [2 "two"] [3 "thisthree"] [4 "four"] ~])
|
|
|
|
::
|
|
|
|
++ test-adjust-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ adjust-with-key four
|
|
|
|
3
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({a/@ud b/tape} (weld (scow %ud a) b))
|
|
|
|
(from-list [[1 "one"] [2 "two"] [3 "3three"] [4 "four"] ~])
|
|
|
|
::
|
|
|
|
++ test-update
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ update four
|
|
|
|
3
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/tape `(maybe tape)`~)
|
|
|
|
(from-list [[1 "one"] [2 "two"] [4 "four"] ~])
|
|
|
|
::
|
|
|
|
++ test-update-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ update-with-key four
|
|
|
|
3
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({a/@u b/tape} `(maybe tape)`[~ (weld (scow %ud a) b)])
|
|
|
|
(from-list [[1 "one"] [2 "two"] [3 "3three"] [4 "four"] ~])
|
|
|
|
::
|
|
|
|
++ test-alter-as-add
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ alter four
|
|
|
|
5
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/(maybe tape) `(maybe tape)`[~ "five"])
|
|
|
|
(from-list [[1 "one"] [2 "two"] [3 "three"] [4 "four"] [5 "five"] ~])
|
|
|
|
::
|
|
|
|
++ test-alter-as-delete
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ alter four
|
|
|
|
2
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/(maybe tape) `(maybe tape)`~)
|
|
|
|
(from-list [[1 "one"] [3 "three"] [4 "four"] ~])
|
|
|
|
::
|
|
|
|
++ test-alter-as-change
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ alter four
|
|
|
|
2
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/(maybe tape) `(maybe tape)`[~ "dos"])
|
|
|
|
(from-list [[1 "one"] [2 "dos"] [3 "three"] [4 "four"] ~])
|
|
|
|
::
|
|
|
|
++ check-alter
|
|
|
|
:: check random dicts of 50 items with 40 random operations done on them
|
|
|
|
:: for validity.
|
|
|
|
%+ check
|
|
|
|
(generate-dict 50)
|
|
|
|
|= a/(dict @ud @ud)
|
|
|
|
:: this is dumb, but use {a} as entropy?
|
|
|
|
=/ gen (random:new-hoon (jam a))
|
|
|
|
=| i/@u
|
|
|
|
|-
|
|
|
|
?: =(i 40)
|
|
|
|
%.y
|
|
|
|
=^ key gen (range:gen 0 100)
|
|
|
|
=^ value gen (range:gen 0 100)
|
|
|
|
=. a %^ alter-with-key a key
|
|
|
|
|= {key/@ud current/(maybe @ud)}
|
|
|
|
^- (maybe @ud)
|
|
|
|
=+ action=(mod key 2)
|
|
|
|
?: =(action 0) :: return nothing
|
|
|
|
~
|
|
|
|
?: =(action 1) :: add/set value
|
|
|
|
`value
|
|
|
|
~ :: impossible
|
|
|
|
?. (valid a)
|
|
|
|
%.n
|
|
|
|
$(i +(i))
|
|
|
|
::
|
|
|
|
++ test-union
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ union
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 "left"] [2 "left"] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
(from-list [[2 "right"] [3 "right"] ~])
|
|
|
|
(from-list [[1 "left"] [2 "left"] [3 "right"] ~])
|
|
|
|
::
|
|
|
|
++ test-union-with
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ union-with
|
|
|
|
(from-list [[1 "left"] [2 "left"] ~])
|
|
|
|
(from-list [[2 "right"] [3 "right"] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({a/tape b/tape} (weld a b))
|
|
|
|
(from-list [[1 "left"] [2 "leftright"] [3 "right"] ~])
|
|
|
|
::
|
|
|
|
++ test-union-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ union-with-key
|
|
|
|
(from-list [[1 "left"] [2 "left"] ~])
|
|
|
|
(from-list [[2 "right"] [3 "right"] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({a/@ud b/tape c/tape} :(weld `tape`(scow %ud a) b c))
|
|
|
|
(from-list [[1 "left"] [2 "2leftright"] [3 "right"] ~])
|
|
|
|
::
|
|
|
|
++ test-map
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(map:dct three crip)
|
2017-12-27 00:03:47 +03:00
|
|
|
(from-list [[1 'one'] [2 'two'] [3 'three'] ~])
|
|
|
|
::
|
|
|
|
++ test-map-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%+ map-with-key three
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({a/@u b/tape} (weld (scow %ud a) b))
|
|
|
|
(from-list [[1 "1one"] [2 "2two"] [3 "3three"] ~])
|
|
|
|
::
|
|
|
|
++ test-map-fold
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ map-fold three
|
|
|
|
"Everything:"
|
2017-12-27 00:03:47 +03:00
|
|
|
|= {accumulator/tape value/tape}
|
2018-03-10 04:27:45 +03:00
|
|
|
[:(weld accumulator " " value) (weld value "X")]
|
|
|
|
:- "Everything: two one three"
|
|
|
|
(from-list [[1 "oneX"] [2 "twoX"] [3 "threeX"] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-map-keys
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%+ map-keys three
|
|
|
|
|=(a/@u (add a 10))
|
2017-12-27 00:03:47 +03:00
|
|
|
(from-list [[11 "one"] [12 "two"] [13 "three"] ~])
|
|
|
|
::
|
|
|
|
++ test-map-keys-with
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ map-keys-with three
|
|
|
|
|=(a/@u 42)
|
2017-12-27 00:03:47 +03:00
|
|
|
weld
|
|
|
|
(from-list [[42 "twothreeone"] ~])
|
|
|
|
::
|
|
|
|
++ test-fold
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ fold three
|
|
|
|
"Everything: "
|
2017-12-27 00:03:47 +03:00
|
|
|
:: todo: this works but replacing with just ++weld causes an out of loom.
|
|
|
|
|= {accumulator/tape value/tape}
|
|
|
|
^- tape
|
|
|
|
(weld accumulator value)
|
|
|
|
"Everything: twoonethree"
|
|
|
|
::
|
|
|
|
++ test-fold-with-keys
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ fold-with-keys three
|
|
|
|
"Everything: "
|
2017-12-27 00:03:47 +03:00
|
|
|
|= {accumulator/tape key/@u value/tape}
|
|
|
|
^- tape
|
|
|
|
:(weld accumulator (scow %ud key) value)
|
|
|
|
"Everything: 2two1one3three"
|
|
|
|
::
|
|
|
|
++ test-elems
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(elems three)
|
2017-12-27 00:03:47 +03:00
|
|
|
["two" "three" "one" ~]
|
|
|
|
::
|
|
|
|
++ test-keys
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(keys three)
|
2017-12-27 00:03:47 +03:00
|
|
|
[2 3 1 ~]
|
|
|
|
::
|
|
|
|
++ test-keys-set
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(keys-set three)
|
2017-12-27 00:03:47 +03:00
|
|
|
(si:nl [2 3 1 ~])
|
|
|
|
::
|
|
|
|
++ test-from-set
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%+ from-set
|
|
|
|
(si:nl [1 2 3 ~])
|
|
|
|
|=(a/@u (scow %ud a))
|
2017-12-27 00:03:47 +03:00
|
|
|
(from-list [[1 "1"] [2 "2"] [3 "3"] ~])
|
|
|
|
::
|
|
|
|
++ test-from-list-with
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ from-list-with
|
2018-03-10 04:27:45 +03:00
|
|
|
[[1 1] [2 1] [2 1] [3 3] ~]
|
2017-12-27 00:03:47 +03:00
|
|
|
add
|
|
|
|
(from-list [[1 1] [2 2] [3 3] ~])
|
|
|
|
::
|
|
|
|
++ test-filter
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ filter
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [2 1] [3 2] [4 1] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/@u !=(a 1))
|
|
|
|
(from-list [[1 1] [2 1] [4 1] ~])
|
|
|
|
::
|
|
|
|
++ test-filter-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ filter-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [2 1] [3 2] [4 1] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({a/@u b/@u} =(a 2))
|
|
|
|
(from-list [[1 1] [3 2] [4 1] ~])
|
|
|
|
::
|
|
|
|
++ test-restrict-keys
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ restrict-keys
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [2 2] [3 3] [4 4] [5 5] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
(si:nl [1 3 5 ~])
|
|
|
|
(from-list [[1 1] [3 3] [5 5] ~])
|
|
|
|
::
|
|
|
|
++ test-without-keys
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ without-keys
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [2 2] [3 3] [4 4] [5 5] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
(si:nl [1 3 5 ~])
|
|
|
|
(from-list [[2 2] [4 4] ~])
|
|
|
|
::
|
|
|
|
++ test-partition
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ partition
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [2 2] [3 3] [4 4] [5 5] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/@u |(=(a 1) =(a 3)))
|
|
|
|
:- (from-list [[1 1] [3 3] ~])
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[2 2] [4 4] [5 5] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-map-maybe
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ map-maybe
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [2 2] [3 3] [4 4] [5 5] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=(a/@u ?:(=(a 3) ~ `a))
|
|
|
|
(from-list [[1 1] [2 2] [4 4] [5 5] ~])
|
|
|
|
::
|
|
|
|
++ test-map-maybe-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
2017-12-27 00:03:47 +03:00
|
|
|
%+ map-maybe-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 2] [2 3] [3 4] [4 5] [5 6] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({k/@u v/@u} ?:(=(k 3) ~ `v))
|
|
|
|
(from-list [[1 2] [2 3] [4 5] [5 6] ~])
|
|
|
|
::
|
|
|
|
++ test-map-either
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%+ map-either
|
|
|
|
(from-list [[1 1] [2 2] [3 3] [4 4] [5 5] ~])
|
|
|
|
|= value/@u
|
|
|
|
?: =(0 (mod value 2))
|
|
|
|
[%& "even"]
|
|
|
|
[%| 1]
|
2017-12-27 00:03:47 +03:00
|
|
|
:- (from-list [[2 "even"] [4 "even"] ~])
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [3 1] [5 1] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-map-either-with-key
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%+ map-either-with-key
|
|
|
|
(from-list [[1 1] [2 1] [3 1] [4 1] [5 1] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|= {key/@u value/@u}
|
|
|
|
?: =(0 (mod key 2))
|
|
|
|
[%& "even"]
|
|
|
|
[%| 1]
|
|
|
|
:- (from-list [[2 "even"] [4 "even"] ~])
|
2018-03-10 04:27:45 +03:00
|
|
|
(from-list [[1 1] [3 1] [5 1] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
::
|
|
|
|
++ test-is-subdict
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
%^ is-subdict-by
|
|
|
|
(from-list [[1 1] [4 4] ~])
|
|
|
|
(from-list [[1 1] [2 2] [3 3] [4 4] [5 5] ~])
|
2017-12-27 00:03:47 +03:00
|
|
|
|=({a/* b/*} =(a b))
|
|
|
|
%.y
|
|
|
|
::
|
|
|
|
++ test-valid
|
2018-03-10 04:27:45 +03:00
|
|
|
%+ expect-eq
|
|
|
|
(valid (from-list [[1 1] [2 2] [3 3] [4 4] [5 5] [6 6] [7 7] [8 8] [9 9] ~]))
|
2017-12-27 00:03:47 +03:00
|
|
|
%.y
|
|
|
|
--
|
|
|
|
|