mirror of
https://github.com/urbit/shrub.git
synced 2024-12-22 10:21:31 +03:00
e888960370
Including these in pkg/arvo has caused many minor problems over the years. We don't want to include them in releases, but this often meant excluding them manually, which was error-prone. Here, we move them out of /pkg/arvo/tests and into /tests. CI will have to be updated to match, since we'll still want to include tests there.
183 lines
3.2 KiB
Plaintext
183 lines
3.2 KiB
Plaintext
/+ *test
|
|
::
|
|
=, contain
|
|
::
|
|
|%
|
|
++ test-basic-clock
|
|
::
|
|
=| c=(clock @u tape)
|
|
:: make max-size reasonable for testing
|
|
::
|
|
=. max-size.c 3
|
|
:: specialize type
|
|
::
|
|
=+ by-clock=(by-clock @u tape)
|
|
:: ensure we get a single key we put in
|
|
::
|
|
=. c (~(put by-clock c) 1 "one")
|
|
=^ maybe1 c (~(get by-clock c) 1)
|
|
=/ results1
|
|
%+ expect-eq
|
|
!> [~ "one"]
|
|
!> maybe1
|
|
::
|
|
=/ results2
|
|
%+ expect-eq
|
|
!> 1
|
|
!> size.c
|
|
:: push that key out of the cache
|
|
::
|
|
=. c (~(put by-clock c) 2 "two")
|
|
=. c (~(put by-clock c) 3 "three")
|
|
=. c (~(put by-clock c) 4 "four")
|
|
::
|
|
=/ results3
|
|
%+ expect-eq
|
|
!> 3
|
|
!> size.c
|
|
::
|
|
=^ maybe2 c (~(get by-clock c) 1)
|
|
=/ results4
|
|
%+ expect-eq
|
|
!> ~
|
|
!> maybe2
|
|
::
|
|
;: weld
|
|
results1
|
|
results2
|
|
results3
|
|
results4
|
|
==
|
|
::
|
|
++ test-clock-purge
|
|
::
|
|
=| c=(clock @u tape)
|
|
:: make max-size reasonable for testing
|
|
::
|
|
=. max-size.c 3
|
|
:: specialize type
|
|
::
|
|
=+ by-clock=(by-clock @u tape)
|
|
:: fill the clock
|
|
::
|
|
=. c (~(put by-clock c) 1 "one")
|
|
=. c (~(put by-clock c) 2 "two")
|
|
=. c (~(put by-clock c) 3 "three")
|
|
:: purge the entire clock
|
|
::
|
|
=. c ~(purge by-clock c)
|
|
::
|
|
;: weld
|
|
%+ expect-eq
|
|
!> 0
|
|
!> size.c
|
|
::
|
|
%+ expect-eq
|
|
!> 3
|
|
!> max-size.c
|
|
::
|
|
%+ expect-eq
|
|
!> ~
|
|
!> lookup.c
|
|
::
|
|
%+ expect-eq
|
|
!> ~
|
|
!> queue.c
|
|
==
|
|
::
|
|
++ test-clock-trim
|
|
::
|
|
=| c=(clock @u tape)
|
|
:: make max-size reasonable for testing
|
|
::
|
|
=. max-size.c 3
|
|
:: specialize type
|
|
::
|
|
=+ by-clock=(by-clock @u tape)
|
|
:: fill the clock
|
|
::
|
|
=. c (~(put by-clock c) 1 "one")
|
|
=. c (~(put by-clock c) 2 "two")
|
|
=. c (~(put by-clock c) 3 "three")
|
|
:: trim 2/3 of the clock
|
|
::
|
|
=. c (~(trim by-clock c) 2)
|
|
::
|
|
;: weld
|
|
%+ expect-eq
|
|
!> 1
|
|
!> size.c
|
|
::
|
|
=^ results1 c (~(get by-clock c) 3)
|
|
%+ expect-eq
|
|
!> [~ "three"]
|
|
!> results1
|
|
::
|
|
%+ expect-eq
|
|
!> 1
|
|
!> ~(wyt by lookup.c)
|
|
==
|
|
::
|
|
++ test-clock-resized-to-zero
|
|
::
|
|
=| c=(clock @u tape)
|
|
:: make max-size reasonable for testing
|
|
::
|
|
=. max-size.c 3
|
|
:: specialize type
|
|
::
|
|
=+ by-clock=(by-clock @u tape)
|
|
:: fill the clock
|
|
::
|
|
=. c (~(put by-clock c) 1 "one")
|
|
=. c (~(put by-clock c) 2 "two")
|
|
=. c (~(put by-clock c) 3 "three")
|
|
:: resize the clock so it has zero elements
|
|
::
|
|
=. c (~(resize by-clock c) 0)
|
|
::
|
|
=/ results1
|
|
%+ expect-eq
|
|
!> 0
|
|
!> size.c
|
|
::
|
|
=/ results2
|
|
%+ expect-eq
|
|
!> ~
|
|
!> lookup.c
|
|
::
|
|
=/ results3
|
|
%+ expect-eq
|
|
!> ~
|
|
!> queue.c
|
|
::
|
|
=/ results4
|
|
%+ expect-eq
|
|
!> 0
|
|
!> max-size.c
|
|
:: trying to get an element just returns ~
|
|
::
|
|
=^ maybe1 c (~(get by-clock c) 3)
|
|
=/ results5
|
|
%+ expect-eq
|
|
!> ~
|
|
!> maybe1
|
|
:: trying to put an element in doesn't mutate the clock
|
|
::
|
|
=. c (~(put by-clock c) 4 "four")
|
|
::
|
|
=/ results6
|
|
%+ expect-eq
|
|
!> 0
|
|
!> size.c
|
|
::
|
|
;: weld
|
|
results1
|
|
results2
|
|
results3
|
|
results4
|
|
results5
|
|
results6
|
|
==
|
|
--
|