2019-05-25 05:03:33 +03:00
|
|
|
/+ *test
|
|
|
|
/= alef /: /===/sys/vane/alef
|
|
|
|
/!noun/
|
|
|
|
::
|
2019-05-28 06:39:42 +03:00
|
|
|
=/ vane (alef !>(..zuse))
|
|
|
|
=/ lane-foo=lane:alef `@uxlane``@`'lane-foo'
|
|
|
|
::
|
2019-05-31 04:29:54 +03:00
|
|
|
=/ items-from-keys
|
|
|
|
|= keys=(list @ud)
|
|
|
|
%+ turn keys
|
|
|
|
|= k=@ud
|
|
|
|
[k `@tas`(add k %a)]
|
|
|
|
::
|
|
|
|
=/ test-items=(list [@ud @tas])
|
|
|
|
(items-from-keys (gulf 0 6))
|
|
|
|
::
|
|
|
|
=/ atom-map ((ordered-map:alef @ud @tas) lte)
|
|
|
|
::
|
2019-05-25 05:03:33 +03:00
|
|
|
|%
|
2019-05-31 04:29:54 +03:00
|
|
|
::
|
|
|
|
+| %ordered-map
|
|
|
|
::
|
|
|
|
++ test-ordered-map-gas ^- tang
|
|
|
|
::
|
|
|
|
=/ a=(tree [@ud @tas]) (gas:atom-map ~ test-items)
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> %.y
|
|
|
|
!> (check-balance:atom-map a)
|
|
|
|
::
|
|
|
|
++ test-ordered-map-tap ^- tang
|
|
|
|
::
|
|
|
|
=/ a=(tree [@ud @tas]) (gas:atom-map ~ test-items)
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> test-items
|
|
|
|
!> (tap:atom-map a)
|
|
|
|
::
|
|
|
|
++ test-ordered-map-pop ^- tang
|
|
|
|
::
|
|
|
|
=/ a=(tree [@ud @tas]) (gas:atom-map ~ test-items)
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> [[0 %a] (gas:atom-map ~ (items-from-keys (gulf 1 6)))]
|
|
|
|
!> (pop:atom-map a)
|
|
|
|
::
|
|
|
|
++ test-ordered-map-peek ^- tang
|
|
|
|
::
|
|
|
|
=/ a=(tree [@ud @tas]) (gas:atom-map ~ test-items)
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> `[0 %a]
|
|
|
|
!> (peek:atom-map a)
|
|
|
|
::
|
2019-05-31 05:18:02 +03:00
|
|
|
++ test-ordered-map-traverse ^- tang
|
|
|
|
::
|
|
|
|
=/ a=(tree [@ud @tas]) (gas:atom-map ~ test-items)
|
|
|
|
::
|
|
|
|
=+ ^- [state=(list @tas) b=(tree [@ud @tas])]
|
|
|
|
%- (traverse:atom-map ,(list @tas))
|
|
|
|
:* a
|
|
|
|
start=3
|
|
|
|
state=~
|
|
|
|
^= f
|
|
|
|
|= [state=(list @tas) item=[key=@ud val=@tas]]
|
|
|
|
^- [[stop=? new-val=(unit @tas)] state=(list @tas)]
|
|
|
|
::
|
|
|
|
~& :* state=state
|
|
|
|
item=item
|
|
|
|
==
|
|
|
|
::
|
|
|
|
?: =(3 (lent state))
|
|
|
|
[[stop=%.y new-val=`val.item] state]
|
|
|
|
[[stop=%.n new-val=~] [val.item state]]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
~& [state b]
|
|
|
|
~
|
|
|
|
::
|
2019-05-31 04:29:54 +03:00
|
|
|
+| %ordered-set
|
|
|
|
::
|
2019-05-27 02:54:23 +03:00
|
|
|
++ test-ordered-set-gas ^- tang
|
|
|
|
::
|
|
|
|
=/ atom-set ((ordered-set:alef @) lte)
|
|
|
|
=/ a=(tree @) (gas:atom-set ~ (gulf 1 7))
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> %.y
|
|
|
|
!> (check-balance:atom-set a)
|
|
|
|
::
|
|
|
|
++ test-ordered-set-tap ^- tang
|
|
|
|
::
|
|
|
|
=/ atom-set ((ordered-set:alef @) lte)
|
|
|
|
=/ a=(tree @) (gas:atom-set ~ (gulf 1 7))
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> (gulf 1 7)
|
|
|
|
!> (tap:atom-set a)
|
|
|
|
::
|
|
|
|
++ test-ordered-set-pop ^- tang
|
|
|
|
::
|
|
|
|
=/ atom-set ((ordered-set:alef @) lte)
|
|
|
|
=/ a=(tree @) (gas:atom-set ~ (gulf 1 7))
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> [1 (gas:atom-set ~ (gulf 2 7))]
|
|
|
|
!> (pop:atom-set a)
|
|
|
|
::
|
|
|
|
++ test-ordered-set-peek ^- tang
|
|
|
|
::
|
|
|
|
=/ atom-set ((ordered-set:alef @) lte)
|
|
|
|
=/ a=(tree @) (gas:atom-set ~ (gulf 1 7))
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> `1
|
|
|
|
!> (peek:atom-set a)
|
|
|
|
::
|
|
|
|
++ test-ordered-set-sift ^- tang
|
|
|
|
::
|
|
|
|
=/ atom-set ((ordered-set:alef @) lte)
|
|
|
|
=/ items=(list @) (gulf 1 7)
|
|
|
|
=/ a=(tree @) (gas:atom-set ~ items)
|
|
|
|
:: reject items less than 3
|
|
|
|
::
|
|
|
|
=/ res (sift:atom-set a |=(@ (lth +< 4)))
|
|
|
|
::
|
|
|
|
;: weld
|
|
|
|
%+ expect-eq
|
|
|
|
!> %.y
|
|
|
|
!> (check-balance:atom-set kept.res)
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> (gas:atom-set ~ (gulf 4 7))
|
|
|
|
!> kept.res
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> (gulf 1 3)
|
|
|
|
!> lost.res
|
|
|
|
==
|
|
|
|
::
|
2019-05-25 05:03:33 +03:00
|
|
|
++ test-packet-encoding ^- tang
|
|
|
|
::
|
|
|
|
=/ =packet:alef
|
|
|
|
:* [sndr=~nec rcvr=~doznec-doznec]
|
|
|
|
encrypted=%.n
|
|
|
|
origin=~
|
|
|
|
content=[12 13]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
=/ encoded (encode-packet:alef packet)
|
|
|
|
=/ decoded (decode-packet:alef encoded)
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> packet
|
|
|
|
!> decoded
|
2019-05-28 06:39:42 +03:00
|
|
|
::
|
|
|
|
++ test-alien-encounter ^- tang
|
|
|
|
::
|
|
|
|
=/ =packet:alef
|
|
|
|
:* [sndr=~nec rcvr=~doznec-doznec]
|
|
|
|
encrypted=%.y
|
|
|
|
origin=~
|
2019-05-28 06:59:53 +03:00
|
|
|
content=%double-secret
|
2019-05-28 06:39:42 +03:00
|
|
|
==
|
|
|
|
=/ =blob:alef (encode-packet:alef packet)
|
|
|
|
::
|
|
|
|
=/ event-args
|
|
|
|
[our=~doznec-doznec eny=0xdead.beef now=~2222.2.2 *sley]
|
|
|
|
::
|
|
|
|
=/ res
|
|
|
|
(call:(vane event-args) ~[//unix] *type %hear lane-foo blob)
|
|
|
|
::
|
|
|
|
;: weld
|
|
|
|
%+ expect-eq
|
|
|
|
!> [~[//unix] %pass /alien %j %pubs ~nec]~
|
|
|
|
!> -.res
|
|
|
|
::
|
|
|
|
%+ expect-eq
|
|
|
|
!> [%alien [lane-foo packet]~ ~]
|
|
|
|
!> (~(got by peers.ames-state.+.res) ~nec)
|
|
|
|
==
|
2019-05-25 05:03:33 +03:00
|
|
|
--
|