diff options
author | Eduardo Julian | 2017-08-22 20:32:34 -0400 |
---|---|---|
committer | Eduardo Julian | 2017-08-22 20:32:34 -0400 |
commit | d99484697f4d5bd78441ab001f487289b9cdc44e (patch) | |
tree | 75ea99ff15bfdd2851a64b34aacebd6921b661c4 /stdlib/test | |
parent | 9ba4a24f61dc545a7670374c05546375e4e6840d (diff) |
- Implemented a file-system library.
Diffstat (limited to '')
-rw-r--r-- | stdlib/test/test/lux/world/fs.lux | 162 |
1 files changed, 162 insertions, 0 deletions
diff --git a/stdlib/test/test/lux/world/fs.lux b/stdlib/test/test/lux/world/fs.lux new file mode 100644 index 000000000..8289beac4 --- /dev/null +++ b/stdlib/test/test/lux/world/fs.lux @@ -0,0 +1,162 @@ +(;module: + lux + (lux [io] + (control [monad #+ do]) + (concurrency ["P" promise] + ["T" task]) + (data ["R" result] + [text] + text/format + [number]) + (time ["i" instant] + ["d" duration]) + (world ["@" fs] + [blob]) + ["r" math/random]) + lux/test + (.. ["_;" blob])) + +(def: truncate-millis + (|>. (i./ 1_000) (i.* 1_000))) + +(context: "File system." + #times +1 + [file-size (|> r;nat (:: @ map (|>. (n.% +100) (n.max +10)))) + dataL (_blob;blob file-size) + dataR (_blob;blob file-size) + code r;nat + last-modified (|> r;int (:: @ map (|>. (:: number;Number<Int> abs) + truncate-millis + d;from-millis + i;absolute)))] + ($_ seq + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +0 code)))] + result (do T;Monad<Task> + [pre (@;exists? file) + _ (@;write dataL file) + post (@;exists? file) + deleted? (@;delete file) + remains? (@;exists? file)] + (wrap (and (not pre) post + deleted? (not remains?))))] + (test "Can create/delete files." + (R;default false result))) + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +1 code)))] + result (do T;Monad<Task> + [_ (@;write dataL file) + output (@;read file) + _ (@;delete file)] + (wrap (:: blob;Eq<Blob> = dataL output)))] + (test "Can write/read files." + (R;default false result))) + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +2 code)))] + result (do T;Monad<Task> + [_ (@;write dataL file) + read-size (@;size file) + _ (@;delete file)] + (wrap (n.= file-size read-size)))] + (test "Can read file size." + (R;default false result))) + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +3 code)))] + result (do T;Monad<Task> + [_ (@;write dataL file) + _ (@;append dataR file) + output (@;read file) + read-size (@;size file) + _ (@;delete file)] + (wrap (and (n.= (n.* +2 file-size) read-size) + (:: blob;Eq<Blob> = dataL (R;assume (blob;slice +0 (n.dec file-size) output))) + (:: blob;Eq<Blob> = dataR (R;assume (blob;slice file-size (n.dec read-size) output))))))] + (test "Can append to files." + (R;default false result))) + (do P;Monad<Promise> + [#let [dir (format "temp_dir_" (%n (n.+ +4 code)))] + result (do T;Monad<Task> + [pre (@;exists? dir) + _ (@;make-dir dir) + post (@;exists? dir) + deleted? (@;delete dir) + remains? (@;exists? dir)] + (wrap (and (not pre) post + deleted? (not remains?))))] + (test "Can create/delete directories." + (R;default false result))) + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +5 code))) + dir (format "temp_dir_" (%n (n.+ +5 code)))] + result (do T;Monad<Task> + [_ (@;write dataL file) + file-is-file (@;file? file) + file-is-directory (@;directory? file) + _ (@;delete file) + _ (@;make-dir dir) + directory-is-file (@;file? dir) + directory-is-directory (@;directory? dir) + _ (@;delete dir)] + (wrap (and file-is-file (not file-is-directory) + (not directory-is-file) directory-is-directory)))] + (test "Can differentiate files from directories." + (R;default false result))) + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +6 code))) + dir (format "temp_dir_" (%n (n.+ +6 code)))] + result (do T;Monad<Task> + [_ (@;make-dir dir) + #let [file' (format dir "/" file)] + _ (@;write dataL file') + read-size (@;size file') + deleted-file (@;delete file') + deleted-dir (@;delete dir)] + (wrap (and (n.= file-size read-size) + deleted-file + deleted-dir)))] + (test "Can create files inside of directories." + (R;default false result))) + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +7 code))) + dir (format "temp_dir_" (%n (n.+ +7 code)))] + result (do T;Monad<Task> + [_ (@;make-dir dir) + #let [file' (format dir "/" file)] + _ (@;write dataL file') + children (@;files dir) + _ (@;delete file') + _ (@;delete dir)] + (wrap (case children + (^ (list child)) + (text;ends-with? file' child) + + _ + false)))] + (test "Can list files inside a directory." + (R;default false result))) + (do P;Monad<Promise> + [#let [file (format "temp_file_" (%n (n.+ +8 code)))] + result (do T;Monad<Task> + [_ (@;write dataL file) + was-modified? (@;set-last-modified last-modified file) + time-read (@;get-last-modified file) + _ (@;delete file)] + (wrap (and was-modified? + (:: i;Eq<Instant> = last-modified time-read))))] + (test "Can change the time of last modification." + (R;default false result))) + (do P;Monad<Promise> + [#let [file0 (format "temp_file_" (%n (n.+ +9 code)) "0") + file1 (format "temp_file_" (%n (n.+ +9 code)) "1")] + result (do T;Monad<Task> + [_ (@;write dataL file0) + pre (@;exists? file0) + moved? (@;move file1 file0) + post (@;exists? file0) + confirmed? (@;exists? file1) + deleted? (@;delete file1)] + (wrap (and pre moved? (not post) + confirmed? deleted?)))] + (test "Can move a file from one path to another." + (R;default false result))) + )) |