1
0
mirror of https://github.com/ilyakooo0/urbit.git synced 2025-01-03 20:52:23 +03:00

naive: spawn and xfer proxy tests

This commit is contained in:
drbeefsupreme 2021-06-10 15:19:31 -04:00
parent 3bba3e5ac0
commit 4c7cdc253a
No known key found for this signature in database
GPG Key ID: B70D5683DE7F9EFC

View File

@ -242,8 +242,9 @@
%manage %.n %manage %.n
%transfer %.y %transfer %.y
== ==
:: TODO: how do i make the following two lines? $? %configure-keys %escape %cancel-escape %adopt
?(%configure-keys %escape %cancel-escape %adopt %reject %detach %set-management-proxy) %reject %detach %set-management-proxy
==
?. =(dominion %l2) ?. =(dominion %l2)
%.n %.n
?+ proxy %.n ?+ proxy %.n
@ -256,14 +257,20 @@
-- --
:: ::
++ filter-tx-type ++ filter-tx-type
|= [=tx-type =event-list] |= [typs=(list =tx-type) =event-list]
|^ |^
(skim event-list filter) (skim event-list filter)
++ filter ++ filter
:: I think I can shorten this a bit with a fold or something
|= =event ^- ? |= =event ^- ?
?: =(tx-type.event tx-type) =/ match=? %.n
%.y |-
%.n ?~ typs match
=/ cur-typ i.typs
%= $
match |(match =(cur-typ tx-type.event))
typs t.typs
==
-- --
:: ::
++ filter-proxy ++ filter-proxy
@ -271,10 +278,8 @@
|^ |^
(skim event-list filter) (skim event-list filter)
++ filter ++ filter
|= =event ^- ? |= =event
?: =(proxy.event proxy) =(proxy.event proxy)
%.y
%.n
-- --
:: ::
++ filter-rank ++ filter-rank
@ -282,10 +287,8 @@
|^ |^
(skim event-list filter) (skim event-list filter)
++ filter ++ filter
|= =event ^- ? |= =event
?: =(rank.event rank) =(rank.event rank)
%.y
%.n
-- --
:: ::
++ filter-owner ++ filter-owner
@ -293,10 +296,8 @@
|^ |^
(skim event-list filter) (skim event-list filter)
++ filter ++ filter
|= =event ^- ? |= =event
?: =(owner.event owner) =(owner.event owner)
%.y
%.n
-- --
:: ::
++ filter-nonce ++ filter-nonce
@ -304,10 +305,8 @@
|^ |^
(skim event-list filter) (skim event-list filter)
++ filter ++ filter
|= =event ^- ? |= =event
?: =(nonce.event nonce) =(nonce.event nonce)
%.y
%.n
-- --
:: ::
++ filter-dominion ++ filter-dominion
@ -315,10 +314,8 @@
|^ |^
(skim event-list filter) (skim event-list filter)
++ filter ++ filter
|= =event ^- ? |= =event
?: =(dominion.event dominion) =(dominion.event dominion)
%.y
%.n
-- --
:: ::
++ make-event-list ^- event-list ++ make-event-list ^- event-list
@ -431,13 +428,19 @@
:: it ought to test, and +success-map says whether or not that :: it ought to test, and +success-map says whether or not that
:: event should succed or fail :: event should succed or fail
:: ::
++ gen-rut-mgmt-jar ++ gen-rut-proxy-jar
^- (jar @p event) ^- (jar @p event)
=/ filter ;: cork =/ filter ;: cork
(cury filter-owner %.y) (cury filter-owner %.y)
(cury filter-tx-type %set-management-proxy)
(cury filter-proxy %own) (cury filter-proxy %own)
(cury filter-nonce %.y) (cury filter-nonce %.y)
%- cury
:- filter-tx-type
:* %set-management-proxy
%set-spawn-proxy
%set-transfer-proxy
~
==
== ==
=/ filtered-events (filter make-event-list) =/ filtered-events (filter make-event-list)
=| mgmt-jar=(jar @p event) =| mgmt-jar=(jar @p event)
@ -454,8 +457,22 @@
== ==
?: =(rank.current-event %planet) ?: =(rank.current-event %planet)
?+ dominion.current-event !! ?+ dominion.current-event !!
%l1 (list-in-jar (ly ~[~rabsum-ravtyd ~radres-tinnyl]) current-event) %l1 %- list-in-jar
%l2 (list-in-jar (ly ~[~dovmul-mogryt ~pidted-dacnum ~pinpun-pilsun ~habtyc-nibpyx ~disryt-nolpet]) current-event) :- %- ly
:+ ~rabsum-ravtyd
~radres-tinnyl
~
current-event
%l2 %- list-in-jar
:- %- ly
:* ~dovmul-mogryt
~pidted-dacnum
~pinpun-pilsun
~habtyc-nibpyx
~disryt-nolpet
~
==
current-event
== ==
$(filtered-events t.filtered-events) $(filtered-events t.filtered-events)
:: ::
@ -473,6 +490,37 @@
:: ::
-- --
:: ::
++ rut-default-args
|= [=ship =event] ^- skim-tx:naive
|^ ^- skim-tx:naive
?+ tx-type.event !!
:: %spawn
:: %transfer-point
:: %configure-keys
:: %escape
:: %cancel-escape
:: %adopt
:: %reject
:: %detach
%set-management-proxy [%set-management-proxy (addr %proxy-test)]
%set-spawn-proxy [%set-spawn-proxy (addr %proxy-test)]
%set-transfer-proxy [%set-transfer-proxy (addr %proxy-test)]
==
::
:: ++ which-ship
:: :: should only matter for spawn and sponsorship actions
:: ?+ ship !!
:: ~rut
:: ~rigrut
:: ==
:: ::
:: ++ set-proxy ^- skim-tx:naive [tx-type.event (addr %proxy-test)]
:: ++ transfer
:: ++ configure-keys
:: ++ sponsor ~
::
--
::
-- --
:: ::
++ l1 ++ l1
@ -614,10 +662,10 @@
|% |%
:: new tests :: new tests
:: ::
++ test-rut-mgmt-proxies ^- tang ++ test-rut-proxies ^- tang
=, l2-event-gen =, l2-event-gen
:: ::
=/ event-jar gen-rut-mgmt-jar =/ event-jar gen-rut-proxy-jar
=| =^state:naive =| =^state:naive
=^ f state (init-rut-full state) =^ f state (init-rut-full state)
=/ initial-state state =/ initial-state state
@ -645,6 +693,7 @@
!> (~(got by suc-map) cur-event) !> (~(got by suc-map) cur-event)
:: ::
!> !>
|^
=^ f =^ f
state state
%- n %- n
@ -653,15 +702,31 @@
=< q =< q
%- gen-tx %- gen-tx
:+ nonce.owner.own:(~(got by points.state) cur-ship) :+ nonce.owner.own:(~(got by points.state) cur-ship)
:+ [cur-ship proxy.cur-event] :- [cur-ship proxy.cur-event]
%set-management-proxy ::tx-type.cur-event why does the tx-type not work? (rut-default-args cur-ship cur-event)
(addr common-mgmt)
(~(got by default-own-keys) cur-ship) (~(got by default-own-keys) cur-ship)
?: .= =< address.management-proxy.own ?+ tx-type.cur-event !!
(~(got by points.state) cur-ship) %set-management-proxy check-mgmt-proxy
(addr common-mgmt) %set-spawn-proxy check-spwn-proxy
%.y %set-transfer-proxy check-xfer-proxy
%.n ==
::
++ check-mgmt-proxy
.= =< address.management-proxy.own
(~(got by points.state) cur-ship)
(addr %proxy-test)
::
++ check-spwn-proxy
.= =< address.spawn-proxy.own
(~(got by points.state) cur-ship)
(addr %proxy-test)
::
++ check-xfer-proxy
.= =< address.transfer-proxy.own
(~(got by points.state) cur-ship)
(addr %proxy-test)
::
--
:: ::
++ test-marbud-l2-change-keys-new ^- tang ++ test-marbud-l2-change-keys-new ^- tang
=/ new-keys [%configure-keys suit encr auth |] =/ new-keys [%configure-keys suit encr auth |]