! Copyright (C) 2009 Keith Lazuka. ! See http://factorcode.org/license.txt for BSD license. USING: accessors fry images images.loader images.normalization images.viewer io io.backend io.directories io.encodings.binary io.files io.pathnames io.streams.byte-array kernel locals namespaces quotations random sequences serialize tools.test ; IN: images.testing :: with-matching-files ( dirpath extension quot -- ) dirpath [ [ dup file-extension extension = quot [ drop ] if ] each ] with-directory-files ; inline : images. ( dirpath extension -- ) [ image. ] with-matching-files ; : ls ( dirpath extension -- ) [ "\"" dup surround print ] with-matching-files ; : save-as-reference-image ( path -- ) [ load-image ] [ fig-name ] bi binary [ serialize ] with-file-writer ; : save-all-as-reference-images ( dirpath extension -- ) [ save-as-reference-image ] with-matching-files ; : load-reference-image ( path -- image ) fig-name binary [ deserialize ] with-file-reader ; :: encode-test ( path image-class -- ) f verbose-tests? [ path load-image dup clone normalize-image 1quotation swap '[ binary [ _ image-class image>stream ] with-byte-writer image-class load-image* normalize-image ] unit-test ] with-variable ; : decode-test ( path -- ) f verbose-tests? [ [ load-image 1quotation ] [ '[ _ load-reference-image ] ] bi unit-test ] with-variable ; : ( -- image ) RGB >>component-order ubyte-components >>component-type ; inline : randomize-image ( image -- image ) dup bytes-per-image random-bytes >>bitmap ;