/+ *test :: /= ford-vane /: /===/sys/vane/ford /!noun/ :: /= hoon-scry /: /===/sys/hoon /hoon/ /= arvo-scry /: /===/sys/arvo /hoon/ /= zuse-scry /: /===/sys/zuse /hoon/ /= txt-scry /: /===/mar/txt /hoon/ /= diff-scry /: /===/mar/txt-diff /hoon/ :: !: =, ford =, format :: =/ test-pit=vase !>(..zuse) =/ ford-gate (ford-vane test-pit) :: |% ++ test-tear ^- tang :: ;: welp %+ expect-eq !> ~['a' 'bc' 'de'] !> (tear:ford-gate 'a-bc-de') :: %+ expect-eq !> ~['abc'] !> (tear:ford-gate 'abc') :: %+ expect-eq !> ~['ab/c'] !> (tear:ford-gate 'ab/c') == :: ++ test-unify-jugs ^- tang :: %+ expect-eq !> ^- (jug @tas @ud) (my ~[[%a (sy 1 2 ~)] [%b (sy 3 4 5 6 ~)] [%c (sy 7 8 ~)]]) !> %+ unify-jugs:ford-gate `(jug @tas @ud)`(my ~[[%a (sy 1 2 ~)] [%b (sy 3 4 ~)]]) `(jug @tas @ud)`(my ~[[%b (sy 5 6 ~)] [%c (sy 7 8 ~)]]) :: ++ test-resource-wire-encoding ^- tang :: ;: welp %+ expect-eq !> /cx/~nul/desk/~1234.5.6/bar/foo !> ^- path %- scry-request-to-path:ford-gate [%c care=%x [[~nul %desk [%da ~1234.5.6]] /foo/bar]] :: %+ expect-eq !> [%c care=%x [[~nul %desk [%da ~1234.5.6]] /foo/bar]] !> %- need (path-to-scry-request:ford-gate /cx/~nul/desk/~1234.5.6/bar/foo) == :: ++ test-parse-scaffold ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] "!. |=(a=@ud +(a))" ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ :: %+ expect-eq !> :- [1 19] :- ~ :_ [[1 19] ""] ^- scaffold:ford-gate :* source-rail=[[~nul %desk] /bar/foo] zuse-version=%309 structures=~ libraries=~ cranes=~ ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [[1 1] [1 19]]] (ream '!. |=(a=@ud +(a))') == == == !> parsed :: ++ test-parse-scaffold-sur-libk ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /- struct, face=other /+ library, *thing !. |=(a a) """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~[[`%struct %struct] [`%face %other]] libraries=~[[`%library %library] [~ %thing]] cranes=~ ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [3 1] [4 8]] (ream '|=(a a)') == == == !> p.u.q.parsed :: ++ test-parse-scaffold-zuse-version ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /? 400 !. |=(a a) """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=400 structures=~ libraries=~ cranes=~ ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [3 8]] (ream '|=(a a)') == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fssg ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /~ !. [a=1 b=3] !. |=(a b) """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [1 5] [1 18]] (ream '[a=1 b=3]') == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [3 8]] (ream '|=(a b)') == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fsbc ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /$ !. |=(a a) !. |=(a b) """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsbc %dbug [/~nul/desk/~1234.5.6/foo/bar [1 5] [1 16]] (ream '|=(a a)') == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [3 8]] (ream '|=(a b)') == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fsbr ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /| /~ ~ /~ ~ == 5 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsbr :~ :* %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [1 9] [1 10]] [%bust %null] == :* %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [2 9] [2 10]] [%bust %null] == == == == ^= sources :~ [%dbug [/~nul/desk/~1234.5.6/foo/bar [4 1] [4 2]] [%sand %ud 5]] == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fsts ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /= a /~ ~ 5 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsts %a %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [1 12] [1 13]] [%bust %null] == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [2 2]] [%sand %ud 5] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fsdt ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /. /~ !. a=5 /~ !. b=6 == 5 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsdt :~ :* %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [1 9] [1 16]] (ream 'a=5') == :* %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [2 9] [2 16]] (ream 'b=6') == == == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [4 1] [4 2]] [%sand %ud 5] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fscm ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /, /path/to/a /~ !. a=5 :: /path/to/b /~ !. b=6 == 1 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fscm :~ :- /path/to/a :* %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [3 7] [3 14]] (ream 'a=5') == :- /path/to/b :* %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [6 7] [6 14]] (ream 'b=6') == == == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [8 1] [8 2]] [%sand %ud 1] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fspm ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /= data /& mark /~ !. a=1 1 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsts %data %fspm [%mark ~] %fssg %dbug [/~nul/desk/~1234.5.6/foo/bar [1 25] [1 32]] (ream 'a=1') == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [2 2]] [%sand %ud 1] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fscb ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /_ /mark/ 8 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fscb %fszy %mark == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [2 2]] [%sand %ud 8] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fssm ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /= data /; !. |=(a=@u +(a)) /~ !. 5 7 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsts %data %fssm :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 7] [2 24]] (ream '|=(a=@u +(a))') == %fssg :* %dbug [/~nul/desk/~1234.5.6/foo/bar [3 7] [3 12]] (ream '5') == == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [4 1] [4 2]] [%sand %ud 7] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fscl ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /= tests /: /===/tests /_ /mark/ 3 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsts %tests %fscl [[~ ~[~ ~ ~ [~ [%sand %tas 495.874.958.708]]]] ~] %fscb %fszy %mark == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [4 1] [4 2]] [%sand %ud 3] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fskt ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /= data /^ (list @ud) /. /~ 1 /~ 2 == 6 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsts %data %fskt :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 7] [2 17]] %make :+ %dbug [/~nul/desk/~1234.5.6/foo/bar [2 8] [2 12]] [%wing ~[%list]] :~ :+ %dbug [/~nul/desk/~1234.5.6/foo/bar [2 13] [2 16]] [%base [%atom %ud]] == == %fsdt :~ :- %fssg :+ %dbug [/~nul/desk/~1234.5.6/foo/bar [3 11] [3 12]] [%sand %ud 1] :: :- %fssg :+ %dbug [/~nul/desk/~1234.5.6/foo/bar [4 11] [4 12]] [%sand %ud 2] == == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [6 1] [6 2]] [%sand %ud 6] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fszp ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /= data /!mark/ 2 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsts %data %fszp %mark == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [2 2]] [%sand %ud 2] == == == !> p.u.q.parsed :: ++ test-parse-scaffold-crane-fszy ^- tang :: =/ parsed %+ (full (parse-scaffold:ford-gate [[~nul %desk %da ~1234.5.6] /bar/foo])) [1 1] """ /= data /mark/ 9 """ ?~ q.parsed [%leaf "failed to parse at {<p.parsed>}"]~ %+ expect-eq !> :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ ^= crane :~ :* %fsts %data %fszy %mark == == ^= sources :~ :* %dbug [/~nul/desk/~1234.5.6/foo/bar [2 1] [2 2]] [%sand %ud 9] == == == !> p.u.q.parsed :: ++ test-literal ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: send a pinned literal, expects a %made response with pinned literal :: ^= call-args [duct=~ type=~ %build ~nul live=%.n [%$ %noun !>(**)]] :: ^= moves :~ :* duct=~ %give %made ~1234.5.6 %complete %success %$ %noun !>(**) == == == :: %+ welp results1 (expect-ford-empty ford-gate ~nul) :: ++ test-autocons-same ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: if we autocons the same schematic, we should get two of it as a result :: ^= call-args :* duct=~ type=~ %build ~nul live=%.n [[%$ %noun !>(**)] [%$ %noun !>(**)]] == :: ^= moves :~ :* duct=~ %give %made ~1234.5.6 %complete %success [%success %$ %noun !>(**)] [%success %$ %noun !>(**)] == == == :: %+ welp results1 (expect-ford-empty ford-gate ~nul) :: ++ test-autocons-different ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: if we autocons different schematics, we get different values :: ^= call-args :* duct=~ type=~ %build ~nul live=%.n [[%$ %noun !>(42)] [%$ %noun !>(43)]] == :: ^= moves :~ :* duct=~ %give %made ~1234.5.6 %complete %success [%success %$ %noun !>(42)] [%success %$ %noun !>(43)] == == == :: %+ welp results1 (expect-ford-empty ford-gate ~nul) :: ++ test-scry-clay-succeed ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-succeed ~1234.5.6 [%noun !>(42)]) :: test a pinned scry which succeeds :: ^= call-args :* duct=~ type=~ %build ~nul live=%.n [%scry %c ren=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~ %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == == == :: %+ welp results1 (expect-ford-empty ford-gate ~nul) :: ++ test-scry-clay-fail ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-fail ~1234.5.6) :: attempting to scry a path which fails should produce an error :: ^= call-args :* duct=~ type=~ %build ~nul live=%.n [%scry %c ren=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~ %give %made ~1234.5.6 %complete %error :~ leaf+"scry failed for" leaf+"%cx /~nul/desk/~1234.5.6/foo/bar" == == == == :: %+ weld results1 (expect-ford-empty ford-gate ~nul) :: ++ test-scry-clay-block ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-block ~1234.5.6) :: when we scry on a blocked path, expect a subscription move :: ^= call-args :* duct=~ type=~ %build ~nul live=%.n [%scry %c ren=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~ %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ %sing %x [%da ~1234.5.6] /foo/bar == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: when clay responds, send a %made :: ^= take-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar duct=~ ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %writ ~ [%x [%da ~1234.5.6] %desk] /bar/foo %noun !>(42)] == :: ^= moves :~ :* duct=~ %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == == == :: ;: welp results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-scry-clay-multiblock ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-block ~1234.5.6) :: when we scry on a blocked path, expect a subscription move :: ^= call-args :* duct=~[/one] type=~ %build ~nul live=%.n [%scry %c ren=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/one] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ %sing %x [%da ~1234.5.6] /foo/bar == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=(scry-block ~1234.5.6) :: when we scry on a blocked path, expect a subscription move :: ^= call-args :* duct=~[/two] type=~ %build ~nul live=%.n [%pin ~1234.5.6 [%scry %c ren=%x rail=[[~nul %desk] /bar/foo]]] == :: ^= moves ~ == :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: when clay responds, send a %made :: ^= take-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar duct=~ ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %writ ~ [%x [%da ~1234.5.6] %desk] /bar/foo %noun !>(42)] == :: ^= moves :~ :* duct=~[/one] %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == :* duct=~[/two] %give %made ~1234.5.7 %complete %success [%scry %noun !>(42)] == == == :: ;: welp results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: ++ test-scry-clay-cancel ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-block ~1234.5.6) :: when we scry on a blocked path, expect a subscription move :: ^= call-args :* duct=~[/one] type=~ %build ~nul live=%.n [%scry %c ren=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/one] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ %sing %x [%da ~1234.5.6] /foo/bar == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/one] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/one] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-scry-clay-live ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-succeed ~1234.5.6 [%noun !>(42)]) :: ^= call-args :* duct=~[/first] type=~ %build ~nul live=%.y [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/first] %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar]~)] == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=(scry-succeed ~1234.5.7 [%noun !>(43)]) :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/first] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/first] %give %made ~1234.5.7 %complete %success [%scry %noun !>(43)] == :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar]~)] == == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/first] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: ++ test-scry-clay-live-again ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-succeed ~1234.5.6 [%noun !>(42)]) :: perform a live scry, we should get a %made and a clay subscription :: ^= call-args :* duct=~[/first] type=~ %build ~nul live=%.y [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/first] %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar]~)] == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=(scry-succeed ~1234.5.7 [%noun !>(42)]) :: ^= call-args :* duct=~[/second] type=~ %build ~nul live=%.y [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/second] %give %made ~1234.5.7 %complete %success [%scry %noun !>(42)] == :* duct=~[/second] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar]~)] == == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/first] type=~ %kill ~nul] ^= moves :~ :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk ~ == == == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.9 scry=scry-is-forbidden :: call-args=[duct=~[/second] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/second] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: tests multiple subscriptions on the same resource at different times :: :: We can depend on the same paths but at different times. Make sure we can :: block on /~nul/desk/~1234.5.7/... and /~nul/desk/~1234.5.8/... at the :: same time. :: ++ test-scry-clay-same-path ^- tang :: =/ scry-type=type [%atom %tas ~] :: =/ blocks=(set @da) (sy ~1234.5.7 ~1234.5.8 ~) :: =/ scry-schematic=schematic:ford-gate [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] =/ autocons=schematic:ford-gate [[%pin ~1234.5.7 scry-schematic] [%pin ~1234.5.8 scry-schematic]] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-blocks blocks) :: call-args=[duct=~[/first] type=~ %build ~nul live=%.y autocons] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: %+ expect-eq !> %- sy :~ :* duct=~[/first] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.7/foo/bar %c %warp [~nul ~nul] %desk `[%sing %x [%da ~1234.5.7] /foo/bar] == :* duct=~[/first] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.8/foo/bar %c %warp [~nul ~nul] %desk `[%sing %x [%da ~1234.5.8] /foo/bar] == == !> (sy moves) == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=(scry-blocks blocks) :: ^= take-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.7/foo/bar duct=~[/first] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type :* %c %writ ~ [%x [%da ~1234.5.7] %desk] /bar/foo %noun scry-type %seven == == :: expected-moves=~ == :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.8 scry=(scry-blocks blocks) :: ^= take-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.8/foo/bar duct=~[/first] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type :* %c %writ ~ [%x [%da ~1234.5.8] %desk] /bar/foo %noun scry-type %eight == == :: ^= expected-moves ^- (list move:ford-gate) :~ :* duct=~[/first] %give %made ~1234.5.6 %complete %success [%success %scry %noun scry-type %seven] [%success %scry %noun scry-type %eight] == == == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.9 scry=scry-is-forbidden :: call-args=[duct=~[/first] type=~ %kill ~nul] :: moves=~ == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: ++ test-pinned-in-past ^- tang :: =/ schematic [%pin ~1234.5.5 [%$ %noun !>(42)]] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: call-args=[duct=~[/pin] type=~ %build ~nul live=%.n schematic] :: ^= expected-moves :~ :* duct=~[/pin] %give %made ~1234.5.6 %complete %success %$ %noun !>(42) == == == results1 :: ++ test-pinned-in-future ^- tang :: =/ schematic [%pin ~1234.5.7 [%$ %noun !>(42)]] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: call-args=[duct=~[/pin] type=~ %build ~nul live=%.n schematic] :: ^= expected-moves :~ :* duct=~[/pin] %give %made ~1234.5.6 %complete %success %$ %noun !>(42) == == == results1 :: ++ test-pinned-in-pin ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=(scry-succeed ~1234.5.6 [%noun !>(42)]) :: ^= call-args :* duct=~[/pinned-in-pin] type=~ %build ~nul live=%.n %pin ~1234.5.7 %pin ~1234.5.6 [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/pinned-in-pin] %give %made ~1234.5.8 %complete [%success %scry %noun !>(42)] == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-pinned-in-live ^- tang :: =/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)]) =/ scry-43 (scry-succeed ~1234.5.7 [%noun !>(43)]) :: =/ schematic=schematic:ford-gate :* %same %pin ~1234.5.6 [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: =/ build=build:ford-gate [~1234.5.6 schematic] =/ result=build-result:ford-gate [%success [%scry %noun !>(42)]] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-42 :: call-args=[duct=~[/live] type=~ %build ~nul live=%.y schematic] moves=[duct=~[/live] %give %made ~1234.5.6 %complete result]~ == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/live] type=~ %kill ~nul] moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-live-build-that-blocks ^- tang :: =/ scry-blocked (scry-block ~1234.5.6) =/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)]) =/ scry-43 (scry-succeed ~1234.5.8 [%noun !>(43)]) :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-blocked :: ^= call-args :* duct=~[/live] type=~ %build ~nul live=%.y [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/live] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ %sing %x [%da ~1234.5.6] /foo/bar == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry-42 :: ^= take-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar duct=~[/live] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %writ ~ [%x [%da ~1234.5.6] %desk] /bar/foo %noun !>(42)] == :: ^= moves :~ :* duct=~[/live] %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == :* duct=~[/live] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar]~)] == == == :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.8 scry=scry-43 :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/live] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.8] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/live] %give %made ~1234.5.8 %complete %success [%scry %noun !>(43)] == :* duct=~[/live] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.8] (sy [%x /foo/bar]~)] == == == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.9 scry=scry-is-forbidden :: call-args=[duct=~[/live] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/live] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: ++ test-live-and-once ^- tang :: =/ scry-blocked (scry-block ~1234.5.6) =/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)]) :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-blocked :: ^= call-args :* duct=~[/live] type=~ %build ~nul live=%.y [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/live] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ %sing %x [%da ~1234.5.6] /foo/bar == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-blocked :: ^= call-args :* duct=~[/once] type=~ %build ~nul live=%.n [%pin ~1234.5.6 [%scry %c ren=%x rail=[[~nul %desk] /bar/foo]]] == :: moves=~ == :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: ^= take-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar duct=~[/live] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %writ ~ [%x [%da ~1234.5.6] %desk] /bar/foo %noun !>(42)] == :: ^= moves :~ :* duct=~[/live] %give %made ~1234.5.6 %complete [%success [%scry %noun !>(42)]] == :* duct=~[/live] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar]~)] == :* duct=~[/once] %give %made ~1234.5.7 %complete [%success [%scry %noun !>(42)]] == == == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.9 scry=scry-is-forbidden :: call-args=[duct=~[/live] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/live] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: ++ test-live-two-deep ^- tang :: =/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)]) =/ scry-43 (scry-succeed ~1234.5.7 [%noun !>(43)]) :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-42 :: ^= call-args :* duct=~[/two-deep-4u] type=~ %build ~nul live=%.y [%same [%scry %c care=%x rail=[[~nul %desk] /bar/foo]]] == :: ^= moves :~ :* duct=~[/two-deep-4u] %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == :* duct=~[/two-deep-4u] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar]~)] == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry-43 :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/two-deep-4u] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/two-deep-4u] %give %made ~1234.5.7 %complete %success [%scry %noun !>(43)] == :* duct=~[/two-deep-4u] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar]~)] == == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/two-deep-4u] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/two-deep-4u] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: ++ test-live-three-deep ^- tang :: =/ scry-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /bar/foo]] [%noun scry-type %it-doesnt-matter] :: :- [%cx [[~nul %desk %da ~1234.5.7] /bar/foo]] [%noun scry-type %changed] == :: =/ scry (scry-with-results scry-results) :: =/ formula=hoon (ream '`@tas`%constant') =/ subject-schematic=schematic:ford-gate [%scry %c %x [~nul %desk] /bar/foo] :: =/ ride=schematic:ford-gate [%ride formula subject-schematic] =/ same=schematic:ford-gate [%same ride] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/ride] type=~ %build ~nul live=%.y same] :: ^= moves :~ :* duct=~[/ride] %give %made ~1234.5.6 %complete [%success [%ride scry-type %constant]] == :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar] ~)] == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/ride] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar] ~)] == == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/ride] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: ++ test-live-triangle ^- tang :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /bar/foo]] [%noun !>(%it-does-in-fact-matter)] :: :- [%cx [[~nul %desk %da ~1234.5.7] /bar/foo]] [%noun !>(%changed)] == :: =/ scry (scry-with-results scry-results) :: =/ formula=hoon (ream '`@tas`%constant') =/ subject-schematic=schematic:ford-gate [%scry %c %x [~nul %desk] /bar/foo] :: =/ ride-type=type [%atom %tas ~] =/ ride=schematic:ford-gate [%ride formula subject-schematic] =/ autocons=schematic:ford-gate [ride subject-schematic] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/ride] type=~ %build ~nul live=%.y autocons] :: ^= moves :~ :* duct=~[/ride] %give %made ~1234.5.6 %complete %success [%success [%ride ride-type %constant]] [%success [%scry %noun !>(%it-does-in-fact-matter)]] == :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar] ~)] == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/ride] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/ride] %give %made ~1234.5.7 %complete %success [%success [%ride ride-type %constant]] [%success [%scry %noun !>(%changed)]] == :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar] ~)] == == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/ride] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: like +test-live-triangle, but with another pinned build :: :: Ensures that we deal with various issues with live builds which :: were partially pinned and their interaction with other live builds. :: ++ test-live-and-pinned-triangle ^- tang :: =/ scry-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /bar/foo]] [%noun scry-type %it-does-in-fact-matter] :: :- [%cx [[~nul %home %da ~1234.5.7] /bar/foo]] [%noun scry-type %it-does-in-fact-matter] == :: =/ scry (scry-with-results scry-results) :: =/ formula=hoon (ream '`@tas`%constant') =/ subject-schematic=schematic:ford-gate [%scry %c %x [~nul %home] /bar/foo] :: =/ ride-type=type [%atom %tas ~] =/ ride=schematic:ford-gate [%ride formula subject-schematic] =/ autocons=schematic:ford-gate [ride subject-schematic] :: =/ static=schematic:ford-gate [%same [%pin ~1234.5.6 autocons]] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/static] type=~ %build ~nul live=%.y static] :: ^= moves :~ :* duct=~[/static] %give %made ~1234.5.6 %complete %success [%success [%ride ride-type %constant]] [%success [%scry %noun scry-type %it-does-in-fact-matter]] == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry :: call-args=[duct=~[/autocons] type=~ %build ~nul live=%.y autocons] :: ^= moves :~ :* duct=~[/autocons] %give %made ~1234.5.7 %complete %success [%success [%ride ride-type %constant]] [%success [%scry %noun scry-type %it-does-in-fact-matter]] == :* duct=~[/autocons] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.7 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.7] (sy [%x /foo/bar] ~)] == == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/static] type=~ %kill ~nul] :: moves=~ == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.9 scry=scry-is-forbidden :: call-args=[duct=~[/autocons] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/autocons] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.7 %c %warp [~nul ~nul] %home ~ == == == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: ++ test-call ^- tang :: =/ sample-schematic=schematic:ford-gate [%$ %noun !>(5)] =/ gate-schematic=schematic:ford-gate [%$ %noun !>(|=(a=@ud +(a)))] =/ call-schematic=schematic:ford-gate [%call gate-schematic sample-schematic] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: call-args=[duct=~[/call] type=~ %build ~nul live=%.y call-schematic] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %success %call *] i.moves) :: =/ result=vase |7:i.moves :: (expect-eq !>(6) result) == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/call] type=~ %kill ~nul] :: moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-call-scry-succeed ^- tang :: =/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)]) :: =/ sample-schematic=schematic:ford-gate [%$ %noun !>(24)] =/ gate-schematic=schematic:ford-gate [%$ %noun !>(|=(a=@ud .^(@ud %cx /~nul/desk/~1234.5.6/foo/bar)))] =/ call-schematic=schematic:ford-gate [%call gate-schematic sample-schematic] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-42 :: call-args=[duct=~[/call] type=~ %build ~nul live=%.y call-schematic] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) :: ?> ?=([* %give %made @da %complete %success %call *] i.moves) :: =/ result=vase |7:i.moves :: (expect-eq !>(42) result) == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/call] type=~ %kill ~nul] :: moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == ++ test-call-scry-fail ^- tang :: =/ scry-failed (scry-fail ~1234.5.6) :: =/ sample-schematic=schematic:ford-gate [%$ %noun !>(24)] =/ gate-schematic=schematic:ford-gate [%$ %noun !>(|=(a=@ud .^(@ud %cx /~nul/desk/~1234.5.6/foo/bar)))] =/ call-schematic=schematic:ford-gate [%call gate-schematic sample-schematic] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-failed :: call-args=[duct=~[/dead] type=~ %build ~nul live=%.y call-schematic] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %error *] i.moves) :: compare the move to the expected move, omitting check on stack trace :: %+ expect-eq !> :* duct=~[/dead] %give %made ~1234.5.6 %complete [%error [leaf+"ford: %call execution failed:" ~]] == !> i.moves(|7 ~) == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/dead] type=~ %kill ~nul] :: moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: :: ++ test-call-scry-block ^- tang :: =/ scry-blocked (scry-block ~1234.5.6) :: =/ sample-schematic=schematic:ford-gate [%$ %noun !>(24)] =/ gate-schematic=schematic:ford-gate [%$ %noun !>(|=(a=@ud .^(@ud %cx /~nul/desk/~1234.5.6/foo/bar)))] =/ call-schematic=schematic:ford-gate [%call gate-schematic sample-schematic] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-blocked :: call-args=[duct=~[/live] type=~ %build ~nul live=%.y call-schematic] :: ^= moves :~ :* duct=~[/live] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ %sing %x [%da ~1234.5.6] /foo/bar == == == :: =^ results2 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.7 scry=scry-blocked :: ^= call-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar duct=~ ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %writ ~ [%x [%da ~1234.5.6] %desk] /bar/foo %noun !>(42)] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %success %call *] i.moves) :: =/ result |7:i.moves :: (expect-eq !>(42) result) == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/live] type=~ %kill ~nul] moves=~ == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: +test-call-scry-varies: call with an argument which varies :: :: This test reads the sample for a %call schematic from clay. This sample :: is a date. Inside of the gate called, we scry on a path based on the :: passed in sample date. :: ++ test-call-scry-varies ^- tang :: =/ date-type=type [%atom %da ~] =/ term-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /timer]] [%noun date-type ~1234.5.6] :: :- [%cx [[~nul %desk %da ~1234.5.6] /result]] [%noun term-type %first] :: :- [%cx [[~nul %desk %da ~1234.5.7] /timer]] [%noun date-type ~1234.5.7] :: :- [%cx [[~nul %desk %da ~1234.5.7] /result]] [%noun term-type %second] == :: =/ scry (scry-with-results scry-results) :: =/ sample-schematic=schematic:ford-gate [%scry [%c care=%x bel=[[~nul %desk] /timer]]] =/ gate-schematic=schematic:ford-gate [%$ %noun !>(|=(a=@da .^(@tas %cx /~nul/desk/(scot %da a)/result)))] =/ call-schematic=schematic:ford-gate [%call gate-schematic sample-schematic] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry :: ^= call-args [duct=~[/call] type=~ %build ~nul live=%.y call-schematic] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %call *] i.moves) :: %+ weld =/ result |7:i.moves (expect-eq !>(%first) result) :: make sure the other move is a subscription :: %+ expect-eq !> :* duct=~[/call] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /timer] ~)] == !> i.t.moves == :: =^ results2 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.7 scry=scry :: ^= call-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/call] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /timer]~)] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %call *] i.moves) :: %+ weld =/ result |7:i.moves (expect-eq !>(%second) result) :: make sure the other move is a subscription :: %+ expect-eq !> :* duct=~[/call] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /timer] ~)] == !> i.t.moves == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/call] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/call] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: ++ test-dude ^- tang :: =/ schematic=schematic:ford-gate :* %dude |.(>%test-no-error<) [%scry [%c care=%x bel=[[~nul %desk] /bar/foo]]] == :: =/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)]) :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-42 :: call-args=[duct=~[/once] type=~ %build ~nul live=%.n schematic] :: ^= moves :~ :* duct=~[/once] %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-dude-error ^- tang :: =/ schematic=schematic:ford-gate :* %dude |.(>%in-the-error-message<) [%scry [%c care=%x bel=[[~nul %desk] /bar/foo]]] == :: =/ scry-42 (scry-fail ~1234.5.6) :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-42 :: call-args=[duct=~[/once] type=~ %build ~nul live=%.n schematic] :: ^= moves :~ :* duct=~[/once] %give %made ~1234.5.6 %complete %error :~ leaf+"%in-the-error-message" leaf+"scry failed for" leaf+"%cx /~nul/desk/~1234.5.6/foo/bar" == == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-hood ^- tang :: =/ scry-type=type [%atom %tas ~] =/ scry %- scry-with-results ^- (map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /hoon/bar/foo]] :* %noun scry-type '!. |=(a=@ud +(a))' == == :: =/ schematic=schematic:ford-gate [%hood [[~nul %desk] /hoon/bar/foo]] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/hood] type=~ %build ~nul live=%.y schematic] :: ^= moves :~ :* duct=~[/hood] %give %made ~1234.5.6 %complete %success %hood :* source-rail=[[~nul %desk] /hoon/bar/foo] zuse-version=309 structures=~ libraries=~ cranes=~ ^= sources :~ :* %dbug [/~nul/desk/0/foo/bar/hoon [1 1] [1 19]] (ream '|=(a=@ud +(a))') == == == == :* duct=~[/hood] %pass /~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar/hoon] ~)] == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/hood] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/hood] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-slim ^- tang :: =/ formula=hoon (ream '(add 2 2)') =/ subject-type=type -:!>(.) :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: ^= call-args [duct=~[/dead] type=~ %build ~nul live=%.y [%slim subject-type formula]] :: ^= moves :~ :* duct=~[/dead] %give %made ~1234.5.6 %complete [%success [%slim (~(mint ut subject-type) [%noun formula])]] == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/dead] type=~ %kill ~nul] :: moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-slit ^- tang :: =/ gate=vase (ride %noun '|=(a=@ud ["one" a])') =/ sample=vase !>(42) :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: call-args=[duct=~[/slit] type=~ %build ~nul live=%.y [%slit gate sample]] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %success %slit *] i.moves) :: we are expecting a type, and all we can do is ensure it nests in :: the right type :: =/ expected-type=type -:!>([*tape *@ud]) =/ actual-type=type |7:i.moves %+ expect-eq !> & !> (~(nest ut actual-type) | expected-type) == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/slit] type=~ %kill ~nul] :: moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-slit-error ^- tang :: =/ gate=vase (ride %noun '|=(a=@ud ["one" a])') =/ sample=vase !>("a tape instead of @ud") :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: call-args=[duct=~[/slit] type=~ %build ~nul live=%.y [%slit gate sample]] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %error *] i.moves) :: ignore last message; contains source positions in the stack trace :: =/ messages=tang (scag 4 `tang`|6:i.moves) :: %+ expect-eq !> :~ [%palm ["." "-" "" ""] [%leaf "have"] [%leaf "\"\""] ~] :~ %palm ["." "-" "" ""] [%leaf "want"] [%palm ["/" "" "" ""] [%leaf "a"] [%leaf "@ud"] ~] == [%leaf "ford: %slit failed:"] [%leaf "nest-fail"] == !> messages == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/slit] type=~ %kill ~nul] :: moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-ride ^- tang :: =/ fun |=(a=@ (add 2 a)) =/ formula=hoon (ream '!: (fun 3)') =/ subject-schematic=schematic:ford-gate [%$ %noun !>(.)] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: ^= call-args :* duct=~[/dead] type=~ %build ~nul live=%.y [%ride formula subject-schematic] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %success %ride *] i.moves) :: =/ result |7:i.moves (expect-eq !>(5) result) == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/dead] type=~ %kill ~nul] moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-ride-scry-succeed ^- tang :: =/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)]) :: =/ formula=hoon (ream '!: .^(* %cx /~nul/desk/~1234.5.6/foo/bar)') =/ subject-schematic=schematic:ford-gate [%$ %noun !>(.)] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-42 :: ^= call-args :* duct=~[/dead] type=~ %build ~nul live=%.y [%ride formula subject-schematic] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %success %ride *] i.moves) :: =/ result |7:i.moves (expect-eq !>(42) result) == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/dead] type=~ %kill ~nul] moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-ride-scry-fail ^- tang :: =/ scry-failed (scry-fail ~1234.5.6) :: =/ formula=hoon (ream '!: .^(* %cx /~nul/desk/~1234.5.6/foo/bar)') =/ subject-schematic=schematic:ford-gate [%$ %noun !>(.)] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-failed :: ^= call-args :* duct=~[/dead] type=~ %build ~nul live=%.y [%ride formula subject-schematic] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %error *] i.moves) :: compare the move to the expected move, omitting check on stack trace :: %+ expect-eq !> :* duct=~[/dead] %give %made ~1234.5.6 %complete [%error [leaf+"ford: %ride failed to execute:" ~]] == !> i.moves(|7 ~) == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: call-args=[duct=~[/dead] type=~ %kill ~nul] moves=~ == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-ride-scry-block ^- tang :: =/ scry-blocked (scry-block ~1234.5.6) :: =/ formula=hoon (ream '!: .^(* %cx /~nul/desk/~1234.5.6/foo/bar)') =/ subject-schematic=schematic:ford-gate [%$ %noun !>(.)] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-blocked :: ^= call-args :* duct=~[/live] type=~ %build ~nul live=%.y [%ride formula subject-schematic] == :: ^= moves :~ :* duct=~[/live] %pass wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar %c %warp [~nul ~nul] %desk ~ %sing %x [%da ~1234.5.6] /foo/bar == == == :: =^ results2 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.7 :: TODO: using +scry-is-forbidden causes a bail: 4 :: scry=scry-blocked :: ^= take-args :* wire=/~nul/scry-request/cx/~nul/desk/~1234.5.6/foo/bar duct=~[/live] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %writ ~ [%x [%da ~1234.5.6] %desk] /bar/foo %noun !>(42)] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete %success %ride *] i.moves) :: =/ result |7:i.moves (expect-eq !>(42) result) == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/live] type=~ %kill ~nul] moves=~ == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: ++ test-ride-scry-promote ^- tang :: =/ scry-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /bar/foo]] [%noun scry-type %it-doesnt-matter] :: :- [%cx [[~nul %desk %da ~1234.5.7] /bar/foo]] [%noun scry-type %changed] == :: =/ scry (scry-with-results scry-results) :: =/ formula=hoon (ream '`@tas`%constant') =/ subject-schematic=schematic:ford-gate [%scry %c %x [~nul %desk] /bar/foo] :: =/ ride=schematic:ford-gate [%ride formula subject-schematic] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/ride] type=~ %build ~nul live=%.y ride] :: ^= moves :~ :* duct=~[/ride] %give %made ~1234.5.6 %complete [%success [%ride scry-type %constant]] == :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar] ~)] == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/ride] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar] ~)] == == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/ride] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 (expect-ford-empty ford-gate ~nul) == :: ++ test-five-oh-fora ^- tang :: =/ scry-type=type [%cell [%face %title [%atom %t ~]] [%face %contents -:!>("")]] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /a/posts]] [%noun scry-type [title='post-a' contents="post-a-contents"]] :: :- [%cx [[~nul %desk %da ~1234.5.6] /b/posts]] [%noun scry-type [title='post-b' contents="post-b-contents"]] :: :- [%cx [[~nul %desk %da ~1234.5.7] /a/posts]] [%noun scry-type [title='post-a' contents="post-a-contents"]] :: :- [%cx [[~nul %desk %da ~1234.5.7] /b/posts]] [%noun scry-type [title='post-b' contents="post-b-contents"]] :: :- [%cx [[~nul %desk %da ~1234.5.8] /a/posts]] [%noun scry-type [title='post-a' contents="post-a-contents-changed"]] == :: =/ scry (scry-with-results scry-results) :: =/ post-a=schematic:ford-gate [%scry [%c %x [~nul %desk] /a/posts]] =/ title-a=schematic:ford-gate [%ride (ream '!: title') post-a] :: =/ post-b=schematic:ford-gate [%scry [%c %x [~nul %desk] /b/posts]] =/ title-b=schematic:ford-gate [%ride (ream '!: title') post-b] :: =/ sidebar=schematic:ford-gate [title-a title-b] :: =/ rendered-a=schematic:ford-gate [post-a sidebar] =/ rendered-b=schematic:ford-gate [post-b sidebar] :: first, ask ford to build rendered-a :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/post-a] type=~ %build ~nul live=%.y rendered-a] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> ?=([^ ^ ~] moves) %+ welp %- verify-post-made :* move=i.moves duct=~[/post-a] type=scry-type date=~1234.5.6 title='post-a' contents="post-a-contents" == %+ expect-eq !> :* duct=~[/post-a] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /posts/a] [%x /posts/b] ~)] == !> i.t.moves == :: =^ results2 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.7 scry=scry :: call-args=[duct=~[/post-b] type=~ %build ~nul live=%.y rendered-b] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> ?=([^ ^ ~] moves) %+ welp %- verify-post-made :* move=i.moves duct=~[/post-b] type=scry-type date=~1234.5.7 title='post-b' contents="post-b-contents" == %+ expect-eq !> :* duct=~[/post-b] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /posts/a] [%x /posts/b] ~)] == !> i.t.moves == :: =^ results3 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.8 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/post-a] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.8] (sy [%x /posts/a]~)] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> ?=([^ ^ ~] moves) %+ welp %- verify-post-made :* move=i.moves duct=~[/post-a] type=scry-type date=~1234.5.8 title='post-a' contents="post-a-contents-changed" == %+ expect-eq !> :* duct=~[/post-a] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.8] (sy [%x /posts/a] [%x /posts/b] ~)] == !> i.t.moves == :: =^ results4 ford-gate %- ford-take :* ford-gate now=~1234.5.9 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.7 duct=~[/post-b] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.8] (sy [%x /posts/a]~)] == :: moves=~ == :: =^ results5 ford-gate %- ford-call :* ford-gate now=~1234.5.10 scry=scry-is-forbidden :: call-args=[duct=~[/post-a] type=~ %kill ~nul] :: moves=~ == :: =^ results6 ford-gate %- ford-call :* ford-gate now=~1234.5.11 scry=scry-is-forbidden :: call-args=[duct=~[/post-b] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/post-a] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 results5 results6 (expect-ford-empty ford-gate ~nul) == :: ++ test-alts ^- tang :: =/ scry-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /one/scry]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /two/scry]] ~ :: :- [%cx [[~nul %home %da ~1234.5.7] /one/scry]] ~ :: :- [%cx [[~nul %home %da ~1234.5.7] /two/scry]] `[%noun scry-type 'scry-two'] :: :- [%cx [[~nul %home %da ~1234.5.8] /one/scry]] `[%noun scry-type 'scry-one'] == :: =/ scry (scry-with-results-and-failures scry-results) :: =/ scry1=schematic:ford-gate [%scry [%c %x [~nul %home] /one/scry]] =/ scry2=schematic:ford-gate [%scry [%c %x [~nul %home] /two/scry]] =/ alts=schematic:ford-gate [%alts [scry1 scry2 ~]] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/alts] type=~ %build ~nul live=%.y alts] :: ^= moves :~ :* duct=~[/alts] %give %made ~1234.5.6 %complete %error :~ [%leaf "%alts: all options failed"] [%leaf "option"] :+ %rose [" " "\{" "}"] :~ [%leaf "scry failed for"] [%leaf "%cx /~nul/home/~1234.5.6/scry/one"] == [%leaf "option"] :+ %rose [" " "\{" "}"] :~ [%leaf "scry failed for"] [%leaf "%cx /~nul/home/~1234.5.6/scry/two"] == == == :* duct=~[/alts] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.6 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.6] (sy [%x /scry/two] [%x /scry/one] ~)] == == == :: =^ results2 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/home/~1234.5.6 duct=~[/alts] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /scry/two]~)] == :: ^= moves :~ :* duct=~[/alts] %give %made ~1234.5.7 %complete %success %alts %success %scry %noun scry-type 'scry-two' == :* duct=~[/alts] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.7 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.7] (sy [%x /scry/two] [%x /scry/one] ~)] == == == :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.8 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/home/~1234.5.6 duct=~[/alts] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.8] (sy [%x /scry/one]~)] == :: ^= moves :~ :* duct=~[/alts] %give %made ~1234.5.8 %complete %success %alts %success %scry %noun scry-type 'scry-one' == :* duct=~[/alts] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.8 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.8] (sy [%x /scry/one] ~)] == == == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.9 scry=scry-is-forbidden :: call-args=[duct=~[/alts] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/alts] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.8 %c %warp [~nul ~nul] %home ~ == == == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: ++ test-alts-and-live ^- tang :: =/ scry-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /one/scry]] ~ :: :- [%cx [[~nul %desk %da ~1234.5.6] /two/scry]] `[%noun scry-type 'scry-two'] :: :- [%cx [[~nul %desk %da ~1234.5.7] /one/scry]] ~ :: :- [%cx [[~nul %desk %da ~1234.5.7] /two/scry]] `[%noun scry-type 'scry-two'] :: :- [%cx [[~nul %desk %da ~1234.5.8] /one/scry]] `[%noun scry-type 'scry-one'] == :: =/ scry (scry-with-results-and-failures scry-results) :: =/ scry2=schematic:ford-gate [%scry [%c %x [~nul %desk] /two/scry]] =/ same=schematic:ford-gate [%same scry2] :: depend on scry2 for the duration of the test :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/same] type=~ %build ~nul live=%.y same] :: ^= moves :~ :* duct=~[/same] %give %made ~1234.5.6 %complete %success %scry %noun scry-type 'scry-two' == :* duct=~[/same] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /scry/two] ~)] == == == :: =/ scry1=schematic:ford-gate [%scry [%c %x [~nul %desk] /one/scry]] =/ alts=schematic:ford-gate [%alts [scry1 scry2 ~]] :: call the alts schematic :: :: The alts schematic should fail to read /scry/one, and should fallback :: to /scry/two. :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry :: call-args=[duct=~[/alts] type=~ %build ~nul live=%.y alts] :: ^= moves :~ :* duct=~[/alts] %give %made ~1234.5.7 %complete %success %alts %success %scry %noun scry-type 'scry-two' == :* duct=~[/alts] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /scry/two] [%x /scry/one] ~)] == == == :: :: tell ford that /scry/one exists now :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.8 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.7 duct=~[/alts] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.8] (sy [%x /scry/one]~)] == :: ^= moves :~ :* duct=~[/alts] %give %made ~1234.5.8 %complete %success %alts %success %scry %noun scry-type 'scry-one' == :: we subscribe to both paths because /same still exists. :: :* duct=~[/alts] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.8] (sy [%x /scry/one] ~)] == == == :: :: kill the /same build :: :: We should no longer subscribe to /scry/two in the resulting clay :: subscription. :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.9 scry=scry :: call-args=[duct=~[/same] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/same] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk ~ == == == :: =^ results5 ford-gate %- ford-call :* ford-gate now=~1234.5.10 scry=scry :: call-args=[duct=~[/alts] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/alts] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 results5 (expect-ford-empty ford-gate ~nul) == :: ++ test-double-alts ^- tang :: =/ scry-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /one/scry]] ~ :- [%cx [[~nul %desk %da ~1234.5.6] /two/scry]] `[%noun scry-type 'scry-two'] :- [%cx [[~nul %desk %da ~1234.5.6] /three/scry]] ~ :: :- [%cx [[~nul %desk %da ~1234.5.7] /one/scry]] ~ :- [%cx [[~nul %desk %da ~1234.5.7] /two/scry]] `[%noun scry-type 'scry-two'] :- [%cx [[~nul %desk %da ~1234.5.7] /three/scry]] ~ :: :- [%cx [[~nul %desk %da ~1234.5.8] /one/scry]] ~ :- [%cx [[~nul %desk %da ~1234.5.8] /two/scry]] `[%noun scry-type 'scry-two'] :- [%cx [[~nul %desk %da ~1234.5.8] /three/scry]] `[%noun scry-type 'scry-three'] :: :- [%cx [[~nul %desk %da ~1234.5.9] /one/scry]] `[%noun scry-type 'scry-one'] :- [%cx [[~nul %desk %da ~1234.5.9] /two/scry]] `[%noun scry-type 'scry-two-changed'] :- [%cx [[~nul %desk %da ~1234.5.9] /three/scry]] `[%noun scry-type 'scry-three'] == :: =/ scry (scry-with-results-and-failures scry-results) :: =/ scry1=schematic:ford-gate [%scry [%c %x [~nul %desk] /one/scry]] =/ scry2=schematic:ford-gate [%scry [%c %x [~nul %desk] /two/scry]] =/ scry3=schematic:ford-gate [%scry [%c %x [~nul %desk] /three/scry]] =/ alts1=schematic:ford-gate [%alts [scry1 scry2 ~]] =/ alts2=schematic:ford-gate [%alts [scry3 scry2 ~]] :: alts1 will depend on both scry1 and scry2 :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/first] type=~ %build ~nul live=%.y alts1] :: ^= moves :~ :* duct=~[/first] %give %made ~1234.5.6 %complete %success %alts %success %scry %noun scry-type 'scry-two' == :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.6 %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /scry/one] [%x /scry/two] ~)] == == == :: alts2 will depend on both scry3 and scry2 :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry :: call-args=[duct=~[/second] type=~ %build ~nul live=%.y alts2] :: ^= moves :~ :* duct=~[/second] %give %made ~1234.5.7 %complete %success %alts %success %scry %noun scry-type 'scry-two' == :* duct=~[/second] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.7 %c %warp [~nul ~nul] %desk ~ %mult [%da ~1234.5.7] (sy [%x /scry/two] [%x /scry/three] ~) == == == :: :: alts2 should now just return 'scry-three' :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.8 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.7 duct=~[/second] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.8] (sy [%x /scry/three]~)] == :: ^= moves :~ :* duct=~[/second] %give %made ~1234.5.8 %complete %success %alts %success %scry %noun scry-type 'scry-three' == :* duct=~[/second] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk ~ %mult [%da ~1234.5.8] (sy [%x /scry/three] ~) == == == :: =^ results4 ford-gate %- ford-take :* ford-gate now=~1234.5.9 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk/~1234.5.6 duct=~[/first] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.9] (sy [%x /scry/one] [%x /scry/two] ~)] == :: ^= moves :~ :* duct=~[/first] %give %made ~1234.5.9 %complete %success %alts %success %scry %noun scry-type 'scry-one' == :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.9 %c %warp [~nul ~nul] %desk ~ %mult [%da ~1234.5.9] (sy [%x /scry/one] ~) == == == :: =^ results5 ford-gate %- ford-call :* ford-gate now=~1234.5.10 scry=scry :: call-args=[duct=~[/first] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/first] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.9 %c %warp [~nul ~nul] %desk ~ == == == :: =^ results6 ford-gate %- ford-call :* ford-gate now=~1234.5.11 scry=scry :: call-args=[duct=~[/second] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/second] %pass wire=/~nul/clay-sub/~nul/desk/~1234.5.8 %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 results5 results6 (expect-ford-empty ford-gate ~nul) == :: +test-cache-reclamation-trivial: reclaim cache on a blank slate ford :: ++ disabled-test-cache-reclamation-trivial :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: send a pinned literal, expects a %made response with pinned literal :: ^= call-args [duct=~[/trivial] type=~ %build ~nul live=%.n [%$ %noun !>(**)]] :: ^= moves :~ :* duct=~[/trivial] %give %made ~1234.5.6 %complete %success %$ %noun !>(**) == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: ask ford to wipe its cache :: call-args=[duct=~[/trivial] type=~ %wipe 10] :: cache wiping should never produce any moves :: moves=~ == :: ;: welp results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ disabled-test-cache-reclamation-live-rebuild :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-succeed ~1234.5.6 [%noun !>(42)]) :: ^= call-args :* duct=~[/build] type=~ %build ~nul live=%.y [%scry %c care=%x rail=[[~nul %desk] /bar/foo]] == :: ^= moves :~ :* duct=~[/build] %give %made ~1234.5.6 %complete %success [%scry %noun !>(42)] == :* duct=~[/build] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar]~)] == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: ask ford to wipe its cache :: call-args=[duct=~[/build] type=~ %wipe 10] :: cache wiping should never produce any moves :: moves=~ == :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=(scry-succeed ~1234.5.7 [%noun !>(43)]) :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk duct=~[/build] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/build] %give %made ~1234.5.7 %complete %success [%scry %noun !>(43)] == :* duct=~[/build] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar]~)] == == == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/build] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/build] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: ++ disabled-test-cache-reclamation-live-promote :: =/ scry-type=type [%atom %tas ~] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /bar/foo]] [%noun scry-type %it-doesnt-matter] :: :- [%cx [[~nul %desk %da ~1234.5.7] /bar/foo]] [%noun scry-type %changed] == :: =/ scry (scry-with-results scry-results) :: =/ formula=hoon (ream '`@tas`%constant') =/ subject-schematic=schematic:ford-gate [%scry %c %x [~nul %desk] /bar/foo] :: =/ ride=schematic:ford-gate [%ride formula subject-schematic] =/ same=schematic:ford-gate [%same ride] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/ride] type=~ %build ~nul live=%.y same] :: ^= moves :~ :* duct=~[/ride] %give %made ~1234.5.6 %complete [%success [%ride scry-type %constant]] == :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /foo/bar] ~)] == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.7 scry=scry-is-forbidden :: ask ford to wipe its cache :: call-args=[duct=~[/ride] type=~ %wipe 10] :: cache wiping should never produce any moves :: moves=~ == :: =^ results3 ford-gate %- ford-take :* ford-gate now=~1234.5.7 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk duct=~[/ride] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)] == :: ^= moves :~ :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.7] (sy [%x /foo/bar] ~)] == == == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/ride] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/ride] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: tests that doing a cache reclamation during the five-oh-fora rebuild works :: ++ disabled-test-five-oh-cache-reclamation ^- tang :: =/ scry-type=type [%cell [%face %title [%atom %t ~]] [%face %contents -:!>("")]] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /a/posts]] [%noun scry-type [title='post-a' contents="post-a-contents"]] :: :- [%cx [[~nul %desk %da ~1234.5.6] /b/posts]] [%noun scry-type [title='post-b' contents="post-b-contents"]] :: :- [%cx [[~nul %desk %da ~1234.5.9] /a/posts]] [%noun scry-type [title='post-a' contents="post-a-contents-changed"]] :: :: unchanged, but might be requested if cache entry gets wiped :: :- [%cx [[~nul %desk %da ~1234.5.9] /b/posts]] [%noun scry-type [title='post-b' contents="post-b-contents"]] == :: =/ scry (scry-with-results scry-results) :: =/ post-a=schematic:ford-gate [%scry [%c %x [~nul %desk] /a/posts]] =/ title-a=schematic:ford-gate [%ride (ream '!: title') post-a] :: =/ post-b=schematic:ford-gate [%scry [%c %x [~nul %desk] /b/posts]] =/ title-b=schematic:ford-gate [%ride (ream '!: title') post-b] :: =/ sidebar=schematic:ford-gate [title-a title-b] :: =/ rendered-a=schematic:ford-gate [post-a sidebar] =/ rendered-b=schematic:ford-gate [post-b sidebar] :: first, ask ford to build rendered-a :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry :: call-args=[duct=~[/post-a] type=~ %build ~nul live=%.y rendered-a] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> ?=([^ ^ ~] moves) %+ welp %- verify-post-made :* move=i.moves duct=~[/post-a] type=scry-type date=~1234.5.6 title='post-a' contents="post-a-contents" == %+ expect-eq !> :* duct=~[/post-a] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk `[%mult [%da ~1234.5.6] (sy [%x /posts/a] [%x /posts/b] ~)] == !> i.t.moves == :: =^ results2 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.7 scry=scry :: call-args=[duct=~[/post-b] type=~ %build ~nul live=%.y rendered-b] :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> ?=([^ ~] moves) %- verify-post-made :* move=i.moves duct=~[/post-b] type=scry-type date=~1234.5.7 title='post-b' contents="post-b-contents" == == :: =^ results3 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/wipe] type=~ %wipe 10] moves=~ == :: =^ results4 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.9 scry=scry :: ^= take-args :* wire=/~nul/clay-sub/~nul/desk duct=~[/post-a] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.9] (sy [%x /posts/a]~)] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: =+ length=(lent moves) :: deal with mug ordering :: :: This test depends on the mugs of types stored in ford, which is :: dependent on the parse tree of this file. There are two valid :: responses, one where we send a spurious move about %post-b :: because it was the entry which was evicted from the cache and one :: where we don't because it wasn't. Check both cases. :: ?: =(length 2) :: the simple case where we don't send a spurious post-b %made :: ?> ?=([^ ^ ~] moves) :: %- verify-post-made :* move=i.moves duct=~[/post-a] type=scry-type date=~1234.5.9 title='post-a' contents="post-a-contents-changed" == :: the complex case :: :: Not only do we send a spurious %made, we don't have a set order :: that these events happen in, so check both ways. :: ?> ?=([^ ^ ^ ~] moves) :: =/ post-a-first=tang %+ welp %- verify-post-made :* move=i.moves duct=~[/post-a] type=scry-type date=~1234.5.9 title='post-a' contents="post-a-contents-changed" == %- verify-post-made :* move=i.t.moves duct=~[/post-b] type=scry-type date=~1234.5.9 title='post-b' contents="post-b-contents" == :: if we got a ~ for post-a-first, everything is fine :: ?~ post-a-first ~ :: otherwise, its either post-b first or an error. :: :: Either way, return post-b first check. :: %+ welp %- verify-post-made :* move=i.moves duct=~[/post-b] type=scry-type date=~1234.5.9 title='post-b' contents="post-b" == :: %- verify-post-made :* move=i.t.moves duct=~[/post-a] type=scry-type date=~1234.5.9 title='post-a' contents="post-a-contents-changed" == == :: =^ results5 ford-gate %- ford-call :* ford-gate now=~1234.5.10 scry=scry-is-forbidden :: call-args=[duct=~[/post-b] type=~ %kill ~nul] moves=~ == :: =^ results6 ford-gate %- ford-call :* ford-gate now=~1234.5.11 scry=scry-is-forbidden :: call-args=[duct=~[/post-a] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/post-a] %pass wire=/~nul/clay-sub/~nul/desk %c %warp [~nul ~nul] %desk ~ == == == :: ;: weld results1 results2 results3 results4 results5 results6 (expect-ford-empty ford-gate ~nul) == :: ++ disabled-slow-test-reef :: =/ hoon-parsed=hoon (rain /~nul/base/~1234.5.6/sys/hoon/hoon hoon-scry) ~& %parsed-hoon :: =/ arvo-parsed=hoon (rain /~nul/base/~1234.5.6/sys/arvo/hoon arvo-scry) ~& %parsed-arvo :: =/ zuse-parsed=hoon (rain /~nul/base/~1234.5.6/sys/zuse/hoon zuse-scry) ~& %parsed-zuse :: =/ pit=vase !>(~) =/ hoon-compiled=vase (slap pit hoon-parsed) ~& %hoon-compiled =/ arvo-compiled=vase (slap hoon-compiled arvo-parsed) ~& %arvo-compiled =/ zuse-compiled=vase (slap arvo-compiled zuse-parsed) ~& %zuse-compiled :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %base %da ~1234.5.6] /hoon/hoon/sys]] [%noun !>(hoon-scry)] :: :- [%cx [[~nul %base %da ~1234.5.6] /hoon/arvo/sys]] [%noun !>(arvo-scry)] :: :- [%cx [[~nul %base %da ~1234.5.6] /hoon/zuse/sys]] [%noun !>(zuse-scry)] == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/reef] type=~ %build ~nul live=%.n [%reef [~nul %base]] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made *] i.moves) =/ result result.p.card.i.moves ?> ?=(%complete -.result) ?> ?=([%success %reef *] +.result) :: =/ kernel=vase vase.build-result.result :: %+ weld =/ result q:(slym (slap (slap kernel [%limb %format]) [%limb %en-beam]) *beam) %+ expect-eq !> (en-beam *beam) !> result :: %+ expect-eq !> & !> (slab %format p.kernel) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-reef-short-circuit ^- tang :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 ^= scry |= [* * =term =beam] ^- (unit (unit cage)) :: ~| [term=term beam=beam] ?> =(%cw term) ?> =([[~nul %home [%da ~1234.5.6]] /hoon/hoon/sys] beam) :: ``[%cass !>(`cass:clay`[ud=1 da=~1234.5.6])] :: ^= call-args :* duct=~[/reef] type=~ %build ~nul live=%.n [%reef [~nul %home]] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made *] i.moves) =/ result result.p.card.i.moves ?> ?=(%complete -.result) ?> ?=([%success %reef *] +.result) :: =/ kernel=vase vase.build-result.result :: %+ weld =/ result q:(slym (slap (slap kernel [%limb %format]) [%limb %en-beam]) *beam) %+ expect-eq !> (en-beam *beam) !> result :: %+ expect-eq !> & !> (slab %format p.kernel) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-path ^- tang :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %desk %da ~1234.5.6] /hoon/bar/foo/lib]] `[%hoon !>(*hoon)] :: :- [%cx [[~nul %desk %da ~1234.5.6] /hoon/foo-bar/lib]] ~ == :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%path disc=[~nul %desk] prefix='lib' raw-path='foo-bar'] == :: ^= moves :~ :* duct=~[/path] %give %made ~1234.5.6 %complete %success %path [[~nul %desk] /hoon/bar/foo/lib] == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-plan-hoon ^- tang :: =/ =hoon (ream '`@tas`%constant') :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: ^= call-args :* duct=~[/plan] type=~ %build ~nul live=%.n %plan source-path=[[~nul %home] /bar/foo] query-string=`coin`[%$ *dime] source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ cranes=~ sources=[hoon]~ == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made *] i.moves) =/ result result.p.card.i.moves ?> ?=(%complete -.result) ?> ?=([%success %plan *] +.result) :: =/ =vase vase.build-result.result :: (expect-eq !>(%constant) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core ^- tang :: =/ hoon-src '`@tas`%constant' =/ hoon-src-type=type [%atom %$ ~] :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo-bar/lib]] [%hoon hoon-src-type hoon-src] == :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/foo-bar/lib]] == :: ^= moves :~ :* duct=~[/path] %give %made ~1234.5.6 %complete %success %core [%atom %tas ~] %constant == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-linker ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/data/sur]] :- %hoon :- hoon-src-type ''' |% += data-type [msg=tape count=@ud] -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/data/lib]] :- %hoon :- hoon-src-type ''' /- data |% ++ do |= [a=data-type:data b=data-type:data] ^- data-type:data [(weld msg.a msg.b) (add count.a count.b)] -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /- *data /+ combiner=data (do:combiner `data-type`["one" 1] `data-type`["two" 2]) ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>(["onetwo" 3]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-multi-hoon ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' |% += data-type [msg=tape count=@ud] -- |% ++ data ^- data-type ["one" 1] -- data ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>(["one" 1]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fsts-fssg ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= one /~ `@u`1 /= two /~ `@u`2 (add one two) ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>(3) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fsdt-fskt ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /^ (list @ud) /. /~ 1 /~ 2 /~ 3 == (weld data [4 5 ~]) ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>([1 2 3 4 5 ~]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fskt-nest-fail ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /^ (list @u) /~ 5 data ''' == :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= moves :~ :* duct=~[/path] %give %made ~1234.5.6 %complete %error :~ :- %leaf "ford: %core on /~nul/home/0/gen/program/hoon failed:" [%leaf "/^ failed: nest-fail"] == == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fssm ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /; |=(a=@u [a a ~]) /~ 5 data ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>([5 5 ~]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fsbr ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /| /^ (list @u) /~ 5 :: /^ (list @u) /~ [6 6 ~] == data ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>([6 6 ~]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fsbr-out-of-options ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /| /^ (list @u) /~ 5 :: /^ @u /~ [6 6 ~] == data ''' == :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= moves :~ :* duct=~[/path] %give %made ~1234.5.6 %complete %error :~ :- %leaf "ford: %core on /~nul/home/0/gen/program/hoon failed:" [%leaf "/| failed: out of options"] == == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-plan-fszp-as-noun ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /!noun/ data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/other/lib]] :- %hoon :- hoon-src-type ''' [1 2 3 ~] ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n :* %plan [[~nul %home] /other/lib] *coin :* source-rail=[[~nul %desk] /bar/foo] zuse-version=309 structures=~ libraries=~ cranes=[%fsts %data [%fszp %noun]]~ sources=[%wing [%data]~]~ == == == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %plan *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>([1 2 3 ~]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fszp-as-mark ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /: /===/lib/other /!somemark/ data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/somemark/mar]] :- %hoon :- hoon-src-type ''' |_ [word=tape num=@] ++ grab |% += noun [tape @] -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/other/lib]] :- %hoon :- hoon-src-type ''' ["five" 5] ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n %core [[~nul %home] /hoon/program/gen] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>(["five" 5]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fscl-fszp ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /: /===/data /!noun/ data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/data]] :- %hoon :- hoon-src-type ''' [1 2 3 ~] ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>([1 2 3 ~]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fscm ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /: /===/data /!noun/ data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/data]] :- %hoon :- hoon-src-type ''' /, /other /~ a=[3 2 1 ~] :: /data /~ a=[1 2 3 ~] == a ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>([1 2 3 ~]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-plan-fsbc ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/other/lib]] :- %hoon :- hoon-src-type ''' /= data /$ %+ cork fuel:html |= gas/epic:eyre [bem.gas (~(got by qix.gas) 'key')] data ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n :* %plan [[~nul %home] /other/lib] :~ %many [%blob *cred:eyre] [%$ [%t %key]] [%$ [%t %value]] [%$ %n ~] == :* source-rail=[[~nul %home] /hoon/other/lib] zuse-version=309 structures=~ libraries=~ cranes=[%fsts %data [%fszp %noun]]~ sources=`(list hoon)`[[%wing [%data]~] ~] == == == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %plan *] build-result.result) :: =/ =vase vase.build-result.result :: %+ expect-eq !>([[[~nul %home [%da ~1234.5.6]] /other/lib] %value]) vase == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fscb ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /^ (map @ta @ud) /: /===/data /_ /!noun/ data ''' :: :- [%cy [[~nul %home %da ~1234.5.6] /data]] :- %arch :- arch-type :- ~ (my ~[[~.one ~] [~.two ~] [~.hoon ~]]) :: :- [%cy [[~nul %home %da ~1234.5.6] /one/data]] :- %arch :- arch-type :- ~ (my ~[[~.hoon ~]]) :: :- [%cy [[~nul %home %da ~1234.5.6] /two/data]] :- %arch :- arch-type :- ~ (my ~[[~.hoon ~]]) :: :: this "hoon" file should be filtered out :: :- [%cy [[~nul %home %da ~1234.5.6] /hoon/data]] :- %arch :- arch-type :- fil=[~ u=0v6] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/one/data]] :- %hoon :- hoon-src-type ''' 1 ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/two/data]] :- %hoon :- hoon-src-type ''' 2 ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/gen]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: =/ expected (my [[%one 1] [%two 2] ~]) (expect-eq !>(expected) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fspm ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- ~ :- %hoon :- hoon-src-type ''' /= data /&second&first&/~["four" 5 "six"] data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/first/mar]] :- ~ :- %hoon :- hoon-src-type ''' |_ [word=tape num=@] ++ grab |% ++ noun |=([a=tape b=@ c=tape] [a b]) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/second/mar]] :- ~ :- %hoon :- hoon-src-type ''' |_ num=@ ++ grab |% ++ first |=([a=tape b=@] b) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/noun/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n %core [[~nul %home] /hoon/program/gen] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result (expect-eq !>(5) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-core-fszy-renderer ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/gen]] :- %hoon :- hoon-src-type ''' /= data /: /===/data /foo/ data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/ren]] :- %hoon :- hoon-src-type ''' /= data /!noun/ data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/data]] :- %hoon :- hoon-src-type ''' [1 2 3 ~] ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n %core [[~nul %home] /hoon/program/gen] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: (expect-eq !>([1 2 3 ~]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-bunt ^- tang :: =/ hoon-src=@ta ''' |_ cell=^ ++ grab |% ++ noun ^ -- -- ''' =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] [%hoon !>(hoon-src)] == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%bunt [~nul %home] %foo] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %bunt *] build-result.result) :: =/ =vase q.cage.build-result.result :: (expect-eq !>([0 0]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-volt ^- tang :: =/ hoon-src=@ta ''' |_ cell=^ ++ grab |% ++ noun ^ -- -- ''' :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] [%hoon !>(hoon-src)] == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%volt [~nul %home] %foo [12 13]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %volt *] build-result.result) :: =/ =vase q.cage.build-result.result :: (expect-eq !>([12 13]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-vale ^- tang :: =/ hoon-src=@ta ''' |_ cell=^ ++ grab |% ++ noun ^ -- -- ''' :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] [%hoon !>(hoon-src)] == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%vale [~nul %home] %foo [12 13]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %vale *] build-result.result) :: =/ =vase q.cage.build-result.result :: (expect-eq !>([12 13]) vase) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-vale-error ^- tang :: =/ hoon-src=@ta ''' |_ cell=^ ++ grab |% ++ noun ^ -- -- ''' :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] [%hoon !>(hoon-src)] == :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%vale [~nul %home] %foo 42] == :: ^= moves :~ :* duct=~[/path] %give %made ~1234.5.6 %complete %error :~ :- %leaf %+ weld "ford: %vale failed: invalid input for mark: " "/~nul/home/~1234.5.6/mar/foo/hoon" :: :- %leaf "ford: %call execution failed:" == == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-cast ^- tang :: =/ foo-mark-src=@ta ''' |_ cell=^ ++ grab |% ++ bar ^ -- -- ''' :: =/ bar-mark-src=@ta ''' |_ sample=[@ @] ++ grab |% += noun [@ @] -- -- ''' :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] `[%hoon hoon-src-type foo-mark-src] :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/bar/mar]] `[%hoon hoon-src-type bar-mark-src] :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/noun/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%cast [~nul %home] %foo [%vale [~nul %home] %bar [12 13]]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %cast *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %foo !>([12 13]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-cast-grow ^- tang :: =/ foo-mark-src=@ta ''' |_ cell=^ ++ grab |% ++ noun ^ -- -- ''' :: =/ bar-mark-src=@ta ''' |_ sample=[@ @] ++ grab |% += noun [@ @] -- ++ grow |% ++ foo sample -- -- ''' :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] `[%hoon hoon-src-type foo-mark-src] :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/bar/mar]] `[%hoon hoon-src-type bar-mark-src] :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/noun/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%cast [~nul %home] %foo [%vale [~nul %home] %bar [12 13]]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %cast *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %foo !>([12 13]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-mute ^- tang :: =/ atom-type=type [%atom %$ ~] :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n %mute subject=[%$ %foo !>([a=42 b=[43 c=44]])] ^= mutations ^- (list [wing schematic:ford-gate]) :~ [~[%a] [%$ %noun atom-type 2]] [~[%c %b] [%$ %noun atom-type 4]] == == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %mute *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %foo !>([2 43 4]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-bake-renderer ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/ren]] :- %hoon :- hoon-src-type ''' /= data /!noun/ data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/data]] :- %hoon :- hoon-src-type ''' [1 2 3 ~] ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%bake %foo *coin `rail:ford-gate`[[~nul %home] /data]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %bake *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %foo !>([1 2 3 ~]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-bake-mark ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] :^ ~ %hoon hoon-src-type ''' |_ cell=^ ++ grab |% ++ bar ^ -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/bar/mar]] :^ ~ %hoon hoon-src-type ''' |_ sample=[@ @] ++ grab |% += noun [@ @] -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/ren]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /bar/data]] `[%bar !>([12 13])] :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/noun/mar]] ~ :: :- [%cy [[~nul %home %da ~1234.5.6] /data]] `[%arch !>(`arch`[fil=~ dir=(my [%bar ~]~)])] :: :- [%cy [[~nul %home %da ~1234.5.6] /bar/data]] `[%arch !>(`arch`[fil=`*@uv dir=~])] == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%bake %foo *coin `rail:ford-gate`[[~nul %home] /data]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %bake *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %foo !>([12 13]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: renderers can fail, and we should fall back to using the mark :: ++ test-bake-mark-fallback ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/dat/ren]] :^ ~ %hoon hoon-src-type ''' /= data /~ !! data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/dat/mar]] :^ ~ %hoon hoon-src-type ''' |_ atom=@ ++ grab |% ++ txt @ -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt/mar]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /txt/data]] :^ ~ %txt hoon-src-type ''' one ''' :: :- [%cy [[~nul %home %da ~1234.5.6] /data]] `[%arch !>(`arch`[fil=~ dir=(my [%txt ~]~)])] :: :- [%cy [[~nul %home %da ~1234.5.6] /txt/data]] `[%arch !>(`arch`[fil=`*@uv dir=~])] == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n [%bake %dat *coin `rail:ford-gate`[[~nul %home] /data]] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %bake *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %dat !>('one') cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-diff ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] :+ %hoon hoon-src-type ''' |_ cell=^ ++ grab |% ++ noun ^ -- ++ grad |% ++ diff |=(^ +<) ++ form %foo -- -- ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n :^ %diff [~nul %home] [%$ %foo !>([12 13])] [%$ %foo !>([17 18])] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %diff *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %foo !>([17 18]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-diff-form ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt/mar]] :^ ~ %hoon hoon-src-type ''' |_ txt=wain ++ grab |% ++ noun wain -- ++ grad |% ++ form %txt-diff ++ diff |= other-txt=wain ^- (urge:clay cord) =, differ (lusk txt other-txt (loss txt other-txt)) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt-diff/mar]] :^ ~ %hoon hoon-src-type ''' |_ txt-diff=(urge:clay cord) ++ grab |% ++ noun (urge:clay cord) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/diff/txt/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n :^ %diff [~nul %home] [%$ %txt !>(~[%a %b])] [%$ %txt !>(~[%a %d])] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %diff *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %txt-diff !>(~[[%& 1] [%| ~[%b] ~[%d]]]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-pact ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt/mar]] :^ ~ %hoon hoon-src-type ''' |_ txt=wain ++ grab |% ++ noun wain -- ++ grad |% ++ form %txt-diff ++ diff |= other-txt=wain ^- (urge:clay cord) =, differ (lusk txt other-txt (loss txt other-txt)) ++ pact |= diff=(urge:clay cord) ^- wain =, differ (lurk txt diff) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt-diff/mar]] :^ ~ %hoon hoon-src-type ''' |_ txt-diff=(urge:clay cord) ++ grab |% ++ noun (urge:clay cord) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/diff/txt/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n :^ %pact [~nul %home] [%$ %txt !>(~[%a %b])] [%$ %txt-diff !>(~[[%& 1] [%| ~[%b] ~[%d]]])] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %pact *] build-result.result) :: =/ =cage cage.build-result.result :: (expect-cage %txt !>(~[%a %d]) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-pact-mark ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt/mar]] :^ ~ %hoon hoon-src-type ''' |_ txt=wain ++ grab |% ++ noun wain -- ++ grad |% ++ form %txt-diff ++ diff |= other-txt=wain ^- (urge:clay cord) =, differ (lusk txt other-txt (loss txt other-txt)) ++ pact |= diff=(urge:clay cord) ^- wain =, differ (lurk txt diff) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/foo/mar]] :^ ~ %hoon hoon-src-type ''' |_ foo=@t ++ grab |% ++ noun @t ++ txt of-wain:format -- ++ grow |% ++ txt (to-wain:format foo) -- ++ grad %txt -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt-diff/mar]] :^ ~ %hoon hoon-src-type ''' |_ txt-diff=(urge:clay cord) ++ grab |% ++ noun (urge:clay cord) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/diff/txt/mar]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/noun/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n :^ %pact [~nul %home] :+ %$ %foo !> ''' a b ''' [%$ %txt-diff !>(~[[%& 1] [%| ~[%b] ~[%d]]])] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %pact *] build-result.result) :: =/ =cage cage.build-result.result :: =/ expected ''' a d ''' :: (expect-cage %foo !>(expected) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-join ^- tang :: =/ hoon-src-type=type [%atom %$ ~] :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt/mar]] :^ ~ %hoon hoon-src-type txt-scry :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt-diff/mar]] :^ ~ %hoon hoon-src-type diff-scry :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/diff/txt/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n :^ %join [~nul %home] %txt :: replace %a with %c on the first line :: :- [%$ %txt-diff !>(~[[%| ~[%a] ~[%c]] [%& 1]])] :: replace %b with %d on the second line :: [%$ %txt-diff !>(~[[%& 1] [%| ~[%b] ~[%d]]])] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %join *] build-result.result) :: =/ =cage cage.build-result.result :: =/ result=(urge:clay cord) ~[[%| ~[%a] ~[%c]] [%| ~[%b] ~[%d]]] (expect-cage %txt-diff !>(result) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-list ^- tang :: =/ ud-type=type [%atom %ud ~] :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: ^= call-args :* duct=~[/count] type=~ %build ~nul live=%.n %list :~ [%$ %noun ud-type 1] [%$ %noun ud-type 2] [%$ %noun ud-type 3] == == :: ^= moves :~ :* duct=~[/count] %give %made ~1234.5.6 %complete %success %list :~ [%success %$ %noun ud-type 1] [%success %$ %noun ud-type 2] [%success %$ %noun ud-type 3] == == == == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-mash ^- tang :: =/ hoon-src-type=type [%atom %$ ~] :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt/mar]] :^ ~ %hoon hoon-src-type txt-scry :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/txt-diff/mar]] :^ ~ %hoon hoon-src-type diff-scry :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/diff/txt/mar]] ~ == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/path] type=~ %build ~nul live=%.n ^- schematic:ford-gate :- %mash :^ [~nul %home] %txt :: replace %a with %c on the first line :: ^= first :+ [~nul %home] %txt-diff ^- schematic:ford-gate [%$ %txt-diff !>(~[[%| ~[%a] ~[%c]] [%& 1]])] :: replace %b with %d on the second line :: ^= second :+ [~nul %home] %txt-diff ^- schematic:ford-gate [%$ %txt-diff !>(~[[%& 1] [%| ~[%b] ~[%d]]])] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=(^ moves) ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %mash *] build-result.result) :: =/ =cage cage.build-result.result :: =/ result=(urge:clay cord) ~[[%| ~[%a] ~[%c]] [%| ~[%b] ~[%d]]] :: (expect-cage %txt-diff !>(result) cage) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: tests multiple cores depending on a rich dependency tree :: :: Test why multiple app cores don't receive dependencies :: ++ test-multi-core-same-dependency ^- tang :: =/ hoon-src-type=type [%atom %$ ~] :: =/ scry-results=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/gh/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add sur-gh-two:gh lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/gh/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-gh-one=1 sur-gh-two=2 sur-gh-three=3] ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/plan-acct/sur]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/acct/plan/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-plan-acct=1 sur-plan-acct=2] ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/lib/old/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/old-lib/lib]] :- ~ :- %hoon :- hoon-src-type ''' [old-lib-val=10 ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/parse/gh/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/gh-parse/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-gh-parse-val=(add old-lib-val sur-gh-three:gh) ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/connector/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-connector-val=(add old-lib-val sur-gh-one:gh) ~] ''' == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/gh] type=~ %build ~nul live=%.y %core [[~nul %home] /hoon/gh/app] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %core *] i.moves) :: =/ =vase vase.build-result.result.p.card.i.moves :: %+ weld (expect-eq !>(13) vase) :: =/ files=(set [%x path]) %- sy :~ [%x /lib/old-lib/hoon] [%x /sur/gh/hoon] [%x /sur/plan-acct/hoon] [%x /sur/plan/acct/hoon] [%x /lib/old/lib/hoon] [%x /app/gh/hoon] [%x /lib/gh/parse/hoon] [%x /lib/gh-parse/hoon] [%x /lib/connector/hoon] == :: %+ expect-eq !> ^- move:ford-gate :* duct=~[/gh] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.6 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.6] files] == !> i.t.moves == :: add a gh2 app which is the same as gh; move dates forward :: :: gh2 is the same except for adding one instead of two. =. scry-results %- my :~ :- [%cx [[~nul %home %da ~1234.5.7] /hoon/gh/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add sur-gh-two:gh lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/gh2/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add sur-gh-one:gh lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/gh/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-gh-one=1 sur-gh-two=2 sur-gh-three=3] ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/plan-acct/sur]] ~ :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/acct/plan/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-plan-acct=1 sur-plan-acct=2] ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/lib/old/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/old-lib/lib]] :- ~ :- %hoon :- hoon-src-type ''' [old-lib-val=10 ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/parse/gh/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/gh-parse/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-gh-parse-val=(add old-lib-val sur-gh-three:gh) ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/connector/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-connector-val=(add old-lib-val sur-gh-one:gh) ~] ''' == :: =^ results2 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.7 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/gh2] type=~ %build ~nul live=%.y %core [[~nul %home] /hoon/gh2/app] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %core *] i.moves) :: =/ =vase vase.build-result.result.p.card.i.moves :: %+ weld (expect-eq !>(12) vase) :: =/ files=(set [%x path]) %- sy :~ [%x /lib/old-lib/hoon] [%x /sur/gh/hoon] [%x /sur/plan-acct/hoon] [%x /sur/plan/acct/hoon] [%x /lib/old/lib/hoon] [%x /app/gh2/hoon] [%x /lib/gh/parse/hoon] [%x /lib/gh-parse/hoon] [%x /lib/connector/hoon] == :: %+ expect-eq !> ^- move:ford-gate :* duct=~[/gh2] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.7 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.7] files] == !> i.t.moves == :: :: add a gh3 app which is the same as gh; move dates forward :: :: gh3 is the same except for adding zero instead of two. =. scry-results %- my :~ :- [%cx [[~nul %home %da ~1234.5.8] /hoon/gh/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add sur-gh-two:gh lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/gh2/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add sur-gh-one:gh lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/gh3/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add 0 lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/gh/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-gh-one=1 sur-gh-two=2 sur-gh-three=3] ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/plan-acct/sur]] ~ :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/acct/plan/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-plan-acct=1 sur-plan-acct=2] ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/lib/old/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/old-lib/lib]] :- ~ :- %hoon :- hoon-src-type ''' [old-lib-val=10 ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/parse/gh/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/gh-parse/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-gh-parse-val=(add old-lib-val sur-gh-three:gh) ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/connector/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-connector-val=(add old-lib-val sur-gh-one:gh) ~] ''' == :: =^ results3 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.8 scry=(scry-with-results-and-failures scry-results) :: ^= call-args :* duct=~[/gh3] type=~ %build ~nul live=%.y %core [[~nul %home] /hoon/gh3/app] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %core *] i.moves) :: =/ =vase vase.build-result.result.p.card.i.moves :: %+ weld (expect-eq !>(11) vase) :: =/ files=(set [%x path]) %- sy :~ [%x /lib/old-lib/hoon] [%x /sur/gh/hoon] [%x /sur/plan-acct/hoon] [%x /sur/plan/acct/hoon] [%x /lib/old/lib/hoon] [%x /app/gh3/hoon] [%x /lib/gh/parse/hoon] [%x /lib/gh-parse/hoon] [%x /lib/connector/hoon] == :: %+ expect-eq !> ^- move:ford-gate :* duct=~[/gh3] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.8 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.8] files] == !> i.t.moves == :: :: change the implementation of /lib/connector/hoon :: =. scry-results %- my :~ :- [%cx [[~nul %home %da ~1234.5.9] /hoon/gh/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add sur-gh-two:gh lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/gh2/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add sur-gh-one:gh lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/gh3/app]] :- ~ :- %hoon :- hoon-src-type ''' /? 314 /- gh, plan-acct /+ gh-parse, connector :: (add 0 lib-connector-val:connector) ''' :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/gh/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-gh-one=1 sur-gh-two=2 sur-gh-three=3] ''' :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/plan-acct/sur]] ~ :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/acct/plan/sur]] :- ~ :- %hoon :- hoon-src-type ''' [sur-plan-acct=1 sur-plan-acct=2] ''' :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/lib/old/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/old-lib/lib]] :- ~ :- %hoon :- hoon-src-type ''' [old-lib-val=10 ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/parse/gh/lib]] ~ :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/gh-parse/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-gh-parse-val=(add old-lib-val sur-gh-three:gh) ~] ''' :: :- [%cx [[~nul %home %da ~1234.5.9] /hoon/connector/lib]] :- ~ :- %hoon :- hoon-src-type ''' /- gh /+ old-lib =, old-lib [lib-connector-val=(add old-lib-val 5) ~] ''' == :: =^ results4 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.9 scry=(scry-with-results-and-failures scry-results) :: ^= take-args :* wire=/~nul/clay-sub/~nul/home/~1234.5.6 duct=~[/gh] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.9] (sy [%x /lib/connector/hoon]~)] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %core *] i.moves) :: =/ =vase vase.build-result.result.p.card.i.moves :: =/ files=(set [%x path]) %- sy :~ [%x /lib/old-lib/hoon] [%x /sur/gh/hoon] [%x /sur/plan-acct/hoon] [%x /sur/plan/acct/hoon] [%x /lib/old/lib/hoon] [%x /app/gh/hoon] [%x /lib/gh/parse/hoon] [%x /lib/gh-parse/hoon] [%x /lib/connector/hoon] == :: ;: weld (expect-eq !>(~[/gh]) !>(duct.i.moves)) (expect-eq !>(17) vase.build-result.result.p.card.i.moves) :: %+ expect-eq !> ^- move:ford-gate :* duct=~[/gh] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.9 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.9] files] == !> i.t.moves == == :: =^ results5 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.9 scry=(scry-with-results-and-failures scry-results) :: ^= take-args :* wire=/~nul/clay-sub/~nul/home/~1234.5.7 duct=~[/gh2] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.9] (sy [%x /lib/connector/hoon]~)] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %core *] i.moves) :: =/ =vase vase.build-result.result.p.card.i.moves :: =/ files=(set [%x path]) %- sy :~ [%x /lib/old-lib/hoon] [%x /sur/gh/hoon] [%x /sur/plan-acct/hoon] [%x /sur/plan/acct/hoon] [%x /lib/old/lib/hoon] [%x /app/gh2/hoon] [%x /lib/gh/parse/hoon] [%x /lib/gh-parse/hoon] [%x /lib/connector/hoon] == :: ;: weld (expect-eq !>(~[/gh2]) !>(duct.i.moves)) (expect-eq !>(16) vase.build-result.result.p.card.i.moves) :: %+ expect-eq !> ^- move:ford-gate :* duct=~[/gh2] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.9 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.9] files] == !> i.t.moves == == :: =^ results6 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.9 scry=(scry-with-results-and-failures scry-results) :: ^= take-args :* wire=/~nul/clay-sub/~nul/home/~1234.5.8 duct=~[/gh3] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.9] (sy [%x /lib/connector/hoon]~)] == :: ^= comparator |= moves=(list move:ford-gate) :: ?> =(2 (lent moves)) ?> ?=([^ ^ ~] moves) ?> ?=([* %give %made @da %complete %success %core *] i.moves) :: =/ =vase vase.build-result.result.p.card.i.moves :: =/ files=(set [%x path]) %- sy :~ [%x /lib/old-lib/hoon] [%x /sur/gh/hoon] [%x /sur/plan-acct/hoon] [%x /sur/plan/acct/hoon] [%x /lib/old/lib/hoon] [%x /app/gh3/hoon] [%x /lib/gh/parse/hoon] [%x /lib/gh-parse/hoon] [%x /lib/connector/hoon] == :: ;: weld (expect-eq !>(~[/gh3]) !>(duct.i.moves)) (expect-eq !>(15) vase.build-result.result.p.card.i.moves) :: %+ expect-eq !> ^- move:ford-gate :* duct=~[/gh3] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.9 %c %warp [~nul ~nul] %home `[%mult [%da ~1234.5.9] files] == !> i.t.moves == == :: =^ results7 ford-gate %- ford-call :* ford-gate now=~1234.5.10 scry=scry-is-forbidden :: call-args=[duct=~[/gh] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/gh] %pass /~nul/clay-sub/~nul/home/~1234.5.9 %c %warp [~nul ~nul] %home ~ == == == :: =^ results8 ford-gate %- ford-call :* ford-gate now=~1234.5.11 scry=scry-is-forbidden :: call-args=[duct=~[/gh2] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/gh2] %pass /~nul/clay-sub/~nul/home/~1234.5.9 %c %warp [~nul ~nul] %home ~ == == == :: =^ results9 ford-gate %- ford-call :* ford-gate now=~1234.5.12 scry=scry-is-forbidden :: call-args=[duct=~[/gh3] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/gh3] %pass /~nul/clay-sub/~nul/home/~1234.5.9 %c %warp [~nul ~nul] %home ~ == == == :: ;: weld results1 results2 results3 results4 results5 results6 results7 results8 results9 (expect-ford-empty ford-gate ~nul) == :: tests that we can do the simple adjacent mark case, and that we use grab :: when both available. :: ++ test-walk-prefer-grab ^- tang :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: =/ scry-results=(map [term beam] cage) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/one/mar]] :- %hoon :- hoon-src-type ''' |_ [a=tape b=@ud] :: convert to ++ grow |% ++ two [b a "grow"] -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/two/mar]] :- %hoon :- hoon-src-type ''' |_ [a=@ud b=tape c=type] ++ grab |% ++ one |=([a=tape b=@ud] [b a "grab"]) -- -- ''' :: :: todo: %cy looks funny here :: :: make sure we can deal with random not-hoon files in mar :- [%cy [[~nul %home %da ~1234.5.6] /js/dummy/mar]] :- %js :- hoon-src-type ''' window.onload = function() ''' == :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-with-results scry-results) :: ^= call-args :* duct=~[/walk] type=~ %build ~nul live=%.y %walk [~nul %home] %one %two == :: ^= moves :~ ^- move:ford-gate :* duct=~[/walk] %give %made ~1234.5.6 %complete %success %walk [%grab %one %two]~ == ^- move:ford-gate :* duct=~[/walk] %pass /~nul/clay-sub/~nul/home/~1234.5.6 %c %warp [~nul ~nul] %home ~ %mult [%da ~1234.5.6] %- sy :~ [%x /mar/two/hoon] [%x /mar/one/hoon] == == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: call-args=[duct=~[/walk] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/walk] %pass /~nul/clay-sub/~nul/home/~1234.5.6 %c %warp [~nul ~nul] %home ~ == == == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: ++ test-walk-large-graph ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=(scry-with-results large-mark-graph) :: ^= call-args :* duct=~[/walk] type=~ %build ~nul live=%.y %walk [~nul %home] %one %four == :: ^= moves :~ ^- move:ford-gate :* duct=~[/walk] %give %made ~1234.5.6 %complete %success %walk [[%grab %one %two] [%grab %two %four] ~] == ^- move:ford-gate :* duct=~[/walk] %pass /~nul/clay-sub/~nul/home/~1234.5.6 %c %warp [~nul ~nul] %home ~ %mult [%da ~1234.5.6] %- sy :~ [%x /mar/one/hoon] [%x /mar/two/hoon] [%x /mar/four/hoon] [%x /mar/five/hoon] == == == == :: =^ results2 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden :: call-args=[duct=~[/walk] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/walk] %pass /~nul/clay-sub/~nul/home/~1234.5.6 %c %warp [~nul ~nul] %home ~ == == == :: ;: weld results1 results2 (expect-ford-empty ford-gate ~nul) == :: +test-walk-large-graph, except we're going to shove data through it. :: ++ test-cast-large-graph ^- tang :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results large-mark-graph) :: ^= call-args :* duct=~[/large] type=~ %build ~nul live=%.n [%cast [~nul %home] %four [%volt [~nul %home] %one ["one" 1]]] == ^= comparator |= moves=(list move:ford-gate) :: ?> =(1 (lent moves)) ?> ?=([^ ~] moves) ?> ?=([* %give %made @da %complete %success %cast *] i.moves) :: =/ result=cage cage.build-result.result.p.card.i.moves :: (expect-cage %four !>(["grab" "one"]) result) == :: ;: weld results1 (expect-ford-empty ford-gate ~nul) == :: ++ test-complex-live-cranes ^- tang :: set the build-cache to 2 to force eviction :: =^ results0 ford-gate %- ford-call :* ford-gate now=~1234.5.5 scry=scry-is-forbidden :: call-args=[duct=~[/config] type=~ %keep [2.048 0]] moves=~ == :: =/ hoon-src-type=type [%atom %$ ~] =/ item-type=type -:!>([%item '']) =/ arch-type=type -:!>(*arch) :: =/ scry-results1=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/program/app]] :- ~ :- %hoon :- hoon-src-type ''' /+ things /= data /^ box:things /; |= a=(map knot item:things) [*config:things a] /: /===/web /_ /item/ :: data ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/things/lib]] :- ~ :- %hoon :- hoon-src-type ''' |% +$ box [config (map knot item)] +$ config [%config @t] +$ item [%item @t] -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/item/mar]] :- ~ :- %hoon :- hoon-src-type ''' /+ things |_ item:things :: convert to ++ grab |% ++ noun item:things -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/item/ren]] ~ :: :- [%cx [[~nul %home %da ~1234.5.6] /item/data1/web]] :- ~ :- %item :- item-type [%item 'one'] :: :- [%cy [[~nul %home %da ~1234.5.6] /web]] `[%arch !>(`arch`[fil=~ dir=(my [[%data1 ~] ~])])] :: :- [%cy [[~nul %home %da ~1234.5.6] /data1/web]] `[%arch !>(`arch`[fil=~ dir=(my [%item ~]~)])] :: :- [%cy [[~nul %home %da ~1234.5.6] /item/data1/web]] `[%arch !>(`arch`[fil=`0v1 dir=~])] == :: =^ results1 ford-gate %- ford-call-with-comparator :* ford-gate now=~1234.5.6 scry=(scry-with-results-and-failures scry-results1) :: ^= call-args ^- [=duct type=* wrapped-task=(hobo task:able:ford-gate)] :* duct=~[/app] type=~ %build ~nul live=%.y [%core source-path=`rail:ford-gate`[[~nul %home] /hoon/program/app]] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(2 (lent moves)) ?> ?=(^ moves) :: ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: =/ result=[[%config @t] (map knot [%item @t])] :- [%config ''] (my [%data1 [%item 'one']] ~) :: (expect-eq !>(result) vase) :: :: TODO: check the subscription? == :: =/ scry-results2=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.7] /hoon/program/app]] :- ~ :- %hoon :- hoon-src-type ''' /+ things /= data /^ box:things /; |= a=(map knot item:things) [*config:things a] /: /===/web /_ /item/ :: data ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/things/lib]] :- ~ :- %hoon :- hoon-src-type ''' |% +$ box [config (map knot item)] +$ config [%config @t] +$ item [%item @t] -- ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/item/mar]] :- ~ :- %hoon :- hoon-src-type ''' /+ things |_ item:things :: convert to ++ grab |% ++ noun item:things -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.7] /hoon/item/ren]] ~ :: :- [%cx [[~nul %home %da ~1234.5.7] /item/data1/web]] :- ~ :- %item :- item-type [%item 'one'] :: :- [%cx [[~nul %home %da ~1234.5.7] /item/data2/web]] :- ~ :- %item :- item-type [%item 'two'] :: :- [%cy [[~nul %home %da ~1234.5.7] /web]] `[%arch !>(`arch`[fil=~ dir=(my [[%data1 ~] [%data2 ~] ~])])] ::a :- [%cy [[~nul %home %da ~1234.5.7] /data1/web]] `[%arch !>(`arch`[fil=~ dir=(my [%item ~]~)])] :: :- [%cy [[~nul %home %da ~1234.5.7] /data2/web]] `[%arch !>(`arch`[fil=~ dir=(my [%item ~]~)])] :- [%cy [[~nul %home %da ~1234.5.7] /item/data1/web]] `[%arch !>(`arch`[fil=`0v1 dir=~])] :: :- [%cy [[~nul %home %da ~1234.5.7] /item/data2/web]] `[%arch !>(`arch`[fil=`0v2 dir=~])] == :: =^ results2 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.7 scry=(scry-with-results-and-failures scry-results2) :: ^= take-args :* wire=/~nul/clay-sub/~nul/home/~1234.5.6 duct=~[/app] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type [%c %wris [%da ~1234.5.7] (sy [%y /web]~)] == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(2 (lent moves)) ?> ?=(^ moves) :: ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: =/ result=[[%config @t] (map knot [%item @t])] :- [%config ''] (my [%data1 [%item 'one']] [%data2 [%item 'two']] ~) :: (expect-eq !>(result) vase) :: :: TODO: check the subscription? == :: =/ scry-results3=(map [term beam] (unit cage)) %- my :~ :- [%cx [[~nul %home %da ~1234.5.8] /hoon/program/app]] :- ~ :- %hoon :- hoon-src-type ''' /+ things /= data /^ box:things /; |= a=(map knot item:things) [*config:things a] /: /===/web /_ /item/ :: data ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/things/lib]] :- ~ :- %hoon :- hoon-src-type ''' |% +$ box [config (map knot item)] +$ config [%config @t] +$ item [%item @t] -- ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/item/mar]] :- ~ :- %hoon :- hoon-src-type ''' /+ things |_ item:things :: convert to ++ grab |% ++ noun item:things -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.8] /hoon/item/ren]] ~ :: :- [%cx [[~nul %home %da ~1234.5.8] /item/data1/web]] :- ~ :- %item :- item-type [%item 'one'] :: :- [%cx [[~nul %home %da ~1234.5.8] /item/data2/web]] :- ~ :- %item :- item-type [%item 'changed-two'] :: :- [%cy [[~nul %home %da ~1234.5.8] /web]] `[%arch !>(`arch`[fil=~ dir=(my [[%data1 ~] [%data2 ~] ~])])] ::a :- [%cy [[~nul %home %da ~1234.5.8] /data1/web]] `[%arch !>(`arch`[fil=~ dir=(my [%item ~]~)])] :: :- [%cy [[~nul %home %da ~1234.5.8] /data2/web]] `[%arch !>(`arch`[fil=~ dir=(my [%item ~]~)])] :- [%cy [[~nul %home %da ~1234.5.8] /item/data1/web]] `[%arch !>(`arch`[fil=`0v1 dir=~])] :: :- [%cy [[~nul %home %da ~1234.5.8] /item/data2/web]] `[%arch !>(`arch`[fil=`0v222 dir=~])] == :: =^ results3 ford-gate %- ford-take-with-comparator :* ford-gate now=~1234.5.7 scry=(scry-with-results-and-failures scry-results3) :: ^= take-args :* wire=/~nul/clay-sub/~nul/home/~1234.5.7 duct=~[/app] ^= wrapped-sign ^- (hypo sign:ford-gate) :- *type :* %c %wris [%da ~1234.5.8] (sy [%x /web/data2/item] [%y /web/data2/item] ~) == == :: ^= comparator |= moves=(list move:ford-gate) ^- tang :: ?> =(2 (lent moves)) ?> ?=(^ moves) :: ?> ?=([* %give %made @da %complete *] i.moves) =/ result result.p.card.i.moves ?> ?=([%success %core *] build-result.result) :: =/ =vase vase.build-result.result :: =/ result=[[%config @t] (map knot [%item @t])] :- [%config ''] (my [%data1 [%item 'one']] [%data2 [%item 'changed-two']] ~) :: (expect-eq !>(result) vase) :: :: TODO: check the subscription? == :: =^ results4 ford-gate %- ford-call :* ford-gate now=~1234.5.8 scry=scry-is-forbidden :: call-args=[duct=~[/app] type=~ %kill ~nul] :: ^= moves :~ :* duct=~[/app] %pass wire=/~nul/clay-sub/~nul/home/~1234.5.8 %c %warp [~nul ~nul] %home ~ == == == :: ;: weld results0 results1 results2 results3 results4 (expect-ford-empty ford-gate ~nul) == :: |data: shared data between cases :: +| data ++ large-mark-graph ^- (map [term beam] cage) :: =/ hoon-src-type=type [%atom %$ ~] =/ arch-type=type -:!>(*arch) :: %- my :~ :- [%cx [[~nul %home %da ~1234.5.6] /hoon/one/mar]] :- %hoon :- hoon-src-type ''' |_ [a=tape b=@ud] :: convert to ++ grow |% ++ two [b a "grow"] ++ five b -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/two/mar]] :- %hoon :- hoon-src-type ''' |_ [a=@ud b=tape c=tape] ++ grab |% ++ one |=([a=tape b=@ud] [b a "grab"]) -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/three/mar]] :- %hoon :- hoon-src-type ''' |_ [b=tape c=tape] ++ grab |% ++ one |=([a=tape b=@ud] [a "grab"]) -- ++ grow |% ++ two [b c] -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/four/mar]] :- %hoon :- hoon-src-type ''' |_ [c=tape b=tape] ++ grab |% ++ two |= [a=@ud b=tape c=tape] [c b] -- -- ''' :: :- [%cx [[~nul %home %da ~1234.5.6] /hoon/five/mar]] :- %hoon :- hoon-src-type ''' |_ a=@u ++ grab |% ++ four :: ignore the value entirely |= [c=tape b=tape] 5 -- ++ grow |% ++ one [a "empty" "grow"] -- -- ''' == :: :: |utilities: helper arms :: ::+| utilities ++ verify-post-made |= $: move=move:ford-gate =duct =type date=@da title=@tas contents=tape == ^- tang :: ?> ?=([* %give %made @da %complete %success ^ *] move) =/ result build-result.result.p.card.move ?> ?=([%success %scry %noun type-a=* @tas *] head.result) ?> ?=([%success ^ *] tail.result) ?> ?=([%success %ride type-title-a=* %post-a] head.tail.result) ?> ?=([%success %ride type-title-b=* %post-b] tail.tail.result) :: ;: welp %+ expect-eq !> duct !> duct.move :: %+ expect-eq !> date !> date.p.card.move :: %+ expect-eq !> [%success %scry %noun *^type [title=title contents=contents]] !> head.result(p.q.cage *^type) :: %+ expect-eq !> & !> (~(nest ut p.q.cage.head.result) | type) :: %+ expect-eq !> 'post-a' vase.head.tail.result :: %+ expect-eq !> 'post-b' vase.tail.tail.result == :: :: +scry-with-results ++ scry-with-results |= results=(map [=term =beam] cage) |= [* (unit (set monk)) =term =beam] ^- (unit (unit cage)) :: ~| scry-with-results+[term=term beam=beam] :: [~ ~ (~(got by results) [term beam])] :: +scry-with-results-and-failures :: ++ scry-with-results-and-failures |= results=(map [=term =beam] (unit cage)) |= [* (unit (set monk)) =term =beam] ^- (unit (unit cage)) :: ~| scry-with-results+[term=term beam=beam] :: [~ (~(got by results) [term beam])] :: +scry-succeed: produces a scry function with a known request and answer :: ++ scry-succeed |= [date=@da result=cage] ^- sley |= [* (unit (set monk)) =term =beam] ^- (unit (unit cage)) :: ~| scry-succeed+[beam+beam term+term] ?> =(term %cx) ?> =(beam [[~nul %desk %da date] /bar/foo]) :: [~ ~ result] :: +scry-fail: produces a scry function with a known request and failed answer :: ++ scry-fail |= date=@da ^- sley |= [* (unit (set monk)) =term =beam] ^- (unit (unit cage)) :: ~| scry-fail+[beam+beam term+term] ?> =(term %cx) ?> =(beam [[~nul %desk %da date] /bar/foo]) :: [~ ~] :: +scry-block: produces a scry function with known request and blocked answer :: ++ scry-block |= date=@da ^- sley |= [* (unit (set monk)) =term =beam] ^- (unit (unit cage)) :: ~| scry-block+[beam+beam term+term] ?> =(term %cx) ?> =(beam [[~nul %desk %da date] /bar/foo]) :: ~ :: ++ scry-blocks |= dates=(set @da) ^- sley |= [* (unit (set monk)) =term =beam] ^- (unit (unit cage)) :: ~| scry-block+[beam+beam term+term] ?> =(term %cx) ?> ?=([%da @da] r.beam) ?> (~(has in dates) p.r.beam) :: ~ :: +scry-is-forbidden: makes sure ford does not attempt to scry :: ++ scry-is-forbidden ^- sley |= [* (unit (set monk)) =term =beam] ^- (unit (unit cage)) :: ~| scry-is-forbidden+[beam+beam term+term] !! :: ++ ford-call |= $: ford-gate=_ford-gate now=@da scry=sley call-args=[=duct type=* wrapped-task=(hobo task:able:ford-gate)] expected-moves=(list move:ford-gate) == ^- [tang _ford-gate] :: =/ ford (ford-gate now=now eny=0xdead.beef scry=scry) :: =^ moves ford-gate %- call:ford call-args :: =/ output=tang %+ expect-eq !> expected-moves !> moves :: [output ford-gate] :: ++ ford-take |= $: ford-gate=_ford-gate now=@da scry=sley take-args=[=wire =duct wrapped-sign=(hypo sign:ford-gate)] expected-moves=(list move:ford-gate) == ^- [tang _ford-gate] :: =/ ford (ford-gate now=now eny=0xdead.beef scry=scry) :: =^ moves ford-gate %- take:ford take-args :: =/ output=tang %+ expect-eq !> expected-moves !> moves :: [output ford-gate] :: +ford-call-with-comparator :: :: Sometimes we can't just do simple comparisons between the moves statements :: and must instead specify a gate that performs the comparisons. :: ++ ford-call-with-comparator |= $: ford-gate=_ford-gate now=@da scry=sley call-args=[=duct type=* wrapped-task=(hobo task:able:ford-gate)] move-comparator=$-((list move:ford-gate) tang) == ^- [tang _ford-gate] :: =/ ford (ford-gate now=now eny=0xdead.beef scry=scry) :: =^ moves ford-gate %- call:ford call-args :: =/ output=tang (move-comparator moves) :: [output ford-gate] :: +ford-take-with-comparator :: ++ ford-take-with-comparator |= $: ford-gate=_ford-gate now=@da scry=sley take-args=[=wire =duct wrapped-sign=(hypo sign:ford-gate)] move-comparator=$-((list move:ford-gate) tang) == ^- [tang _ford-gate] :: =/ ford (ford-gate now=now eny=0xdead.beef scry=scry) :: =^ moves ford-gate %- take:ford take-args :: =/ output=tang (move-comparator moves) :: [output ford-gate] :: +expect-cage: assert that the actual cage has the right mark and vase :: ++ expect-cage |= [mark=term expected=vase actual=cage] %+ weld %+ expect-eq !> mark !> p.actual :: (expect-eq expected q.actual) :: +expect-ford-empty: assert that ford's state is one empty ship :: :: At the end of every test, we want to assert that we have cleaned up all :: state. :: ++ expect-ford-empty |= [ford-gate=_ford-gate ship=@p] ^- tang :: =^ results1 ford-gate %- ford-call :* ford-gate now=~1234.5.6 scry=scry-is-forbidden call-args=[duct=~[/empty] type=~ [%keep 0 0]] expected-moves=~ == :: =/ ford *ford-gate =/ state (~(got by state-by-ship.ax.+>+<.ford) ship) :: =/ default-state *ford-state:ford :: =. max-size.compiler-cache.state max-size.compiler-cache.default-state =. max-size.queue.build-cache.state max-size.queue.build-cache.default-state =. next-anchor-id.build-cache.state 0 :: %+ welp results1 :: ?: =(default-state state) ~ :: =/ build-state=(list tank) %- zing %+ turn ~(tap by builds.state) |= [build=build:ford build-status=build-status:ford] :~ [%leaf (build-to-tape:ford build)] [%leaf "requesters: {<requesters.build-status>}"] [%leaf "clients: {<~(tap in ~(key by clients.build-status))>}"] == :: =/ braces [[' ' ' ' ~] ['{' ~] ['}' ~]] :: :~ [%leaf "failed to cleanup"] [%leaf "builds.state:"] [%rose braces build-state] == --