summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rwxr-xr-xtests/quoted-printable.scm26
1 files changed, 21 insertions, 5 deletions
diff --git a/tests/quoted-printable.scm b/tests/quoted-printable.scm
index c57c833..cc1b957 100755
--- a/tests/quoted-printable.scm
+++ b/tests/quoted-printable.scm
@@ -19,19 +19,35 @@
(use-modules (email quoted-printable)
(ice-9 iconv)
+ (srfi srfi-1)
(srfi srfi-64))
(test-begin "quoted-printable")
-(test-equal "quoted-printable wikipedia example"
- (bytevector->string
- (quoted-printable-decode "J'interdis aux marchands de vanter trop leur marchandises. Car ils se font =
+(let ((decoded-text
+ "J'interdis aux marchands de vanter trop leur marchandises. Car ils se font vite pédagogues et t'enseignent comme but ce qui n'est par essence qu'un moyen, et te trompant ainsi sur la route à suivre les voilà bientôt qui te dégradent, car si leur musique est vulgaire ils te fabriquent pour te la vendre une âme vulgaire.")
+ (encoded-text
+ "J'interdis aux marchands de vanter trop leur marchandises. Car ils se font =
vite p=C3=A9dagogues et t'enseignent comme but ce qui n'est par essence qu'=
un moyen, et te trompant ainsi sur la route =C3=A0 suivre les voil=C3=A0 bi=
ent=C3=B4t qui te d=C3=A9gradent, car si leur musique est vulgaire ils te f=
abriquent pour te la vendre une =C3=A2me vulgaire.")
- "UTF-8")
- "J'interdis aux marchands de vanter trop leur marchandises. Car ils se font vite pédagogues et t'enseignent comme but ce qui n'est par essence qu'un moyen, et te trompant ainsi sur la route à suivre les voilà bientôt qui te dégradent, car si leur musique est vulgaire ils te fabriquent pour te la vendre une âme vulgaire.")
+ (charset "UTF-8"))
+ (test-equal "quoted-printable wikipedia example: decoding"
+ (bytevector->string (quoted-printable-decode encoded-text) charset)
+ decoded-text)
+
+ (test-equal "quoted-printable wikipedia example: encoding"
+ (quoted-printable-encode
+ (string->bytevector decoded-text charset))
+ encoded-text)
+
+ (test-assert "quoted-printable wikipedia example: encoded output should not be more than 76 columns wide"
+ (every (lambda (line)
+ (<= (string-length line) 76))
+ (string-split (quoted-printable-encode
+ (string->bytevector decoded-text charset))
+ #\newline))))
(test-equal "q-encoding wikipedia example"
(bytevector->string