aboutsummaryrefslogtreecommitdiff
path: root/stdlib/test
diff options
context:
space:
mode:
authorEduardo Julian2018-07-09 23:40:48 -0400
committerEduardo Julian2018-07-09 23:40:48 -0400
commit25c48836e80dcaed6c2cbb11a14d3353da37620e (patch)
tree6c01e942271126b560695aa51d0e1657fc291525 /stdlib/test
parent7c53a09d0ba1e443dd60dfdc4b8d8b134fcd120c (diff)
- Fixes: Part 3.
Diffstat (limited to '')
-rw-r--r--stdlib/test/test/lux/world/file.lux213
1 files changed, 104 insertions, 109 deletions
diff --git a/stdlib/test/test/lux/world/file.lux b/stdlib/test/test/lux/world/file.lux
index 75f08e97c..e126b8703 100644
--- a/stdlib/test/test/lux/world/file.lux
+++ b/stdlib/test/test/lux/world/file.lux
@@ -2,14 +2,13 @@
lux
(lux [io]
(control [monad #+ do])
- (concurrency ["P" promise]
- ["T" task])
- (data ["e" error]
+ (concurrency [promise])
+ (data [error]
[text]
text/format
[number])
- (time ["i" instant]
- ["d" duration])
+ (time [instant]
+ [duration])
(world ["@" file]
[blob])
["r" math/random])
@@ -27,113 +26,111 @@
code r.nat
last-modified (|> r.int (:: @ map (|>> (:: number.Number<Int> abs)
truncate-millis
- d.from-millis
- i.absolute)))]
+ duration.from-millis
+ instant.absolute)))]
($_ seq
- (wrap (do P.Monad<Promise>
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +0 code)))]
- result (P.future
- (do io.Monad<Process>
- [pre (@.exists? file)
- _ (@.write dataL file)
- post (@.exists? file)
- deleted? (@.delete file)
- remains? (@.exists? file)]
- (wrap (and (not pre) post
- deleted? (not remains?)))))]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [pre! (@.exists? @.JVM@System file)
+ _ (:: @.JVM@System write dataL file)
+ post! (@.exists? @.JVM@System file)
+ _ (:: @.JVM@System delete file)
+ remains? (@.exists? @.JVM@System file)]
+ (wrap (and (not pre!) post!
+ (not remains?)))))]
(assert "Can create/delete files."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +1 code)))]
- result (P.future
- (do io.Monad<Process>
- [_ (@.write dataL file)
- output (@.read file)
- _ (@.delete file)]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System write dataL file)
+ output (:: @.JVM@System read file)
+ _ (:: @.JVM@System delete file)]
(wrap (:: blob.Equivalence<Blob> = dataL output))))]
(assert "Can write/read files."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +2 code)))]
- result (P.future
- (do io.Monad<Process>
- [_ (@.write dataL file)
- read-size (@.size file)
- _ (@.delete file)]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System write dataL file)
+ read-size (:: @.JVM@System size file)
+ _ (:: @.JVM@System delete file)]
(wrap (n/= file-size read-size))))]
(assert "Can read file size."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +3 code)))]
- result (P.future
- (do io.Monad<Process>
- [_ (@.write dataL file)
- _ (@.append dataR file)
- output (@.read file)
- read-size (@.size file)
- _ (@.delete file)]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System write dataL file)
+ _ (:: @.JVM@System append dataR file)
+ output (:: @.JVM@System read file)
+ read-size (:: @.JVM@System size file)
+ _ (:: @.JVM@System delete file)]
(wrap (and (n/= (n/* +2 file-size) read-size)
- (:: blob.Equivalence<Blob> = dataL (e.assume (blob.slice +0 (dec file-size) output)))
- (:: blob.Equivalence<Blob> = dataR (e.assume (blob.slice file-size (dec read-size) output)))))))]
+ (:: blob.Equivalence<Blob> = dataL (error.assume (blob.slice +0 (dec file-size) output)))
+ (:: blob.Equivalence<Blob> = dataR (error.assume (blob.slice file-size (dec read-size) output)))))))]
(assert "Can append to files."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [dir (format "temp_dir_" (%n (n/+ +4 code)))]
- result (P.future
- (do io.Monad<Process>
- [pre (@.exists? dir)
- _ (@.make-directory dir)
- post (@.exists? dir)
- deleted? (@.delete dir)
- remains? (@.exists? dir)]
- (wrap (and (not pre) post
- deleted? (not remains?)))))]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [pre! (@.exists? @.JVM@System dir)
+ _ (:: @.JVM@System make-directory dir)
+ post! (@.exists? @.JVM@System dir)
+ _ (:: @.JVM@System delete dir)
+ remains? (@.exists? @.JVM@System dir)]
+ (wrap (and (not pre!) post!
+ (not remains?)))))]
(assert "Can create/delete directories."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +5 code)))
dir (format "temp_dir_" (%n (n/+ +5 code)))]
- result (P.future
- (do io.Monad<Process>
- [_ (@.write dataL file)
- file-is-file (@.file? file)
- file-is-directory (@.directory? file)
- _ (@.delete file)
- _ (@.make-directory dir)
- directory-is-file (@.file? dir)
- directory-is-directory (@.directory? dir)
- _ (@.delete dir)]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System write dataL file)
+ file-is-file (:: @.JVM@System file? file)
+ file-is-directory (:: @.JVM@System directory? file)
+ _ (:: @.JVM@System delete file)
+ _ (:: @.JVM@System make-directory dir)
+ directory-is-file (:: @.JVM@System file? dir)
+ directory-is-directory (:: @.JVM@System directory? dir)
+ _ (:: @.JVM@System delete dir)]
(wrap (and file-is-file (not file-is-directory)
(not directory-is-file) directory-is-directory))))]
(assert "Can differentiate files from directories."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +6 code)))
dir (format "temp_dir_" (%n (n/+ +6 code)))]
- result (P.future
- (do io.Monad<Process>
- [_ (@.make-directory dir)
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System make-directory 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))))]
+ _ (:: @.JVM@System write dataL file')
+ read-size (:: @.JVM@System size file')
+ _ (:: @.JVM@System delete file')
+ _ (:: @.JVM@System delete dir)]
+ (wrap (n/= file-size read-size))))]
(assert "Can create files inside of directories."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +7 code)))
dir (format "temp_dir_" (%n (n/+ +7 code)))]
- result (P.future
- (do io.Monad<Process>
- [_ (@.make-directory dir)
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System make-directory dir)
#let [file' (format dir "/" file)]
- _ (@.write dataL file')
- children (@.files dir)
- _ (@.delete file')
- _ (@.delete dir)]
+ _ (:: @.JVM@System write dataL file')
+ children (:: @.JVM@System files dir)
+ _ (:: @.JVM@System delete file')
+ _ (:: @.JVM@System delete dir)]
(wrap (case children
(^ (list child))
(text.ends-with? file' child)
@@ -141,32 +138,30 @@
_
false))))]
(assert "Can list files inside a directory."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file (format "temp_file_" (%n (n/+ +8 code)))]
- result (P.future
- (do io.Monad<Process>
- [_ (@.write dataL file)
- was-modified? (@.modify last-modified file)
- time-read (@.last-modified file)
- _ (@.delete file)]
- (wrap (and was-modified?
- (:: i.Equivalence<Instant> = last-modified time-read)))))]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System write dataL file)
+ _ (:: @.JVM@System modify last-modified file)
+ time-read (:: @.JVM@System last-modified file)
+ _ (:: @.JVM@System delete file)]
+ (wrap (:: instant.Equivalence<Instant> = last-modified time-read))))]
(assert "Can change the time of last modification."
- (e.default false result))))
- (wrap (do P.Monad<Promise>
+ (error.default false result))))
+ (wrap (do promise.Monad<Promise>
[#let [file0 (format "temp_file_" (%n (n/+ +9 code)) "0")
file1 (format "temp_file_" (%n (n/+ +9 code)) "1")]
- result (P.future
- (do io.Monad<Process>
- [_ (@.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?))))]
+ result (promise.future
+ (do (:: @.JVM@System &monad)
+ [_ (:: @.JVM@System write dataL file0)
+ pre! (@.exists? @.JVM@System file0)
+ _ (:: @.JVM@System move file1 file0)
+ post! (@.exists? @.JVM@System file0)
+ confirmed? (@.exists? @.JVM@System file1)
+ _ (:: @.JVM@System delete file1)]
+ (wrap (and pre! (not post!) confirmed?))))]
(assert "Can move a file from one path to another."
- (e.default false result))))
+ (error.default false result))))
)))