3 (luna-define-class test-riece-log (lunit-test-case))
5 (defun test-riece-log-delete-directory (directory)
6 (let ((files (directory-files directory t nil t)))
8 (if (file-directory-p (car files))
9 (unless (member (file-name-nondirectory (car files)) '("." ".."))
10 (test-riece-log-delete-directory (car files)))
11 (delete-file (car files)))
12 (setq files (cdr files)))
13 (delete-directory directory)))
15 (luna-define-method lunit-test-case-setup ((case test-riece-log))
16 (setq riece-log-directory
17 (expand-file-name (make-temp-name "test-riece-log")
18 (if (featurep 'xemacs)
20 temporary-file-directory))
21 test-riece-log-directory
22 (expand-file-name "=23riece" riece-log-directory))
23 (make-directory riece-log-directory)
24 (make-directory test-riece-log-directory)
25 (write-region "03:14 <test> a b c\n03:15 <test> a b c\n" nil
26 (expand-file-name "20380119.log" test-riece-log-directory)
28 (write-region "03:14 <test> 1 2 3\n" nil
29 (expand-file-name "20380118.log" test-riece-log-directory)
32 (luna-define-method lunit-test-case-teardown ((case test-riece-log))
33 (test-riece-log-delete-directory riece-log-directory))
35 (luna-define-method test-riece-log-flashback-1 ((case test-riece-log))
36 (let ((riece-log-flashback 3)
37 riece-log-directory-map)
41 (concat "03:14 <test> 1 2 3 (2038/01/18)\n"
42 "03:14 <test> a b c (2038/01/19)\n"
43 "03:15 <test> a b c (2038/01/19)\n")
45 (riece-log-flashback (riece-make-identity "#riece" ""))
48 (luna-define-method test-riece-log-flashback-2 ((case test-riece-log))
49 (let ((riece-log-flashback t)
50 riece-log-directory-map)
55 (riece-log-flashback (riece-make-identity "#riece" ""))
58 (luna-define-method test-riece-log-encode-file-name ((case test-riece-log))
59 (let (riece-log-file-name-coding-system)
63 (riece-log-encode-file-name "#riece")))
66 (equal "=23riece=3A=2A=2Ejp"
67 (riece-log-encode-file-name "#riece:*.jp")))
71 (riece-log-encode-file-name "#riece=")))))
73 (luna-define-method test-riece-log-encode-file-name-mule
74 ((case test-riece-log))
75 (let ((riece-log-file-name-coding-system 'iso-8859-1))
78 (equal "=23\xABriece\xBB"
79 (riece-log-encode-file-name
81 (make-char 'latin-iso8859-1 43)
82 (make-char 'latin-iso8859-1 59))))))
83 (let ((riece-log-file-name-coding-system 'iso-2022-jp))
86 (equal "=23=1B=24B=24j=21=3C=249=1B=28B"
87 (riece-log-encode-file-name
89 (make-char 'japanese-jisx0208 36 106)
90 (make-char 'japanese-jisx0208 33 60)
91 (make-char 'japanese-jisx0208 36 57)))))))
93 (luna-define-method test-riece-log-decode-file-name ((case test-riece-log))
94 (let (riece-log-file-name-coding-system)
98 (riece-log-decode-file-name "=23riece")))
102 (riece-log-decode-file-name "=23riece=3A=2A=2Ejp")))
106 (riece-log-decode-file-name "=23riece==")))))
108 (luna-define-method test-riece-log-decode-file-name-mule
109 ((case test-riece-log))
110 (let ((riece-log-file-name-coding-system 'iso-8859-1))
113 (equal (format "#%criece%c"
114 (make-char 'latin-iso8859-1 43)
115 (make-char 'latin-iso8859-1 59))
116 (riece-log-decode-file-name
117 "=23\xABriece\xBB"))))
118 (let ((riece-log-file-name-coding-system 'iso-2022-jp))
121 (equal (format "#%c%c%c"
122 (make-char 'japanese-jisx0208 36 106)
123 (make-char 'japanese-jisx0208 33 60)
124 (make-char 'japanese-jisx0208 36 57))
125 (riece-log-decode-file-name
126 "=23=1B=24B=24j=21=3C=249=1B=28B")))))