aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/libraries/sqlite/unix/sqlite-3.5.1/test/badutf.test
diff options
context:
space:
mode:
authordan miller2007-10-20 02:49:29 +0000
committerdan miller2007-10-20 02:49:29 +0000
commite36d23a85ebff914d74bb541558c2b6082b78edb (patch)
tree54b58fdf162e78af64055282a6035c8d2443389d /libraries/sqlite/unix/sqlite-3.5.1/test/badutf.test
parent* Fixed an issue whereby avatar chat distances were being calculated against ... (diff)
downloadopensim-SC-e36d23a85ebff914d74bb541558c2b6082b78edb.zip
opensim-SC-e36d23a85ebff914d74bb541558c2b6082b78edb.tar.gz
opensim-SC-e36d23a85ebff914d74bb541558c2b6082b78edb.tar.bz2
opensim-SC-e36d23a85ebff914d74bb541558c2b6082b78edb.tar.xz
sqlite source (unix build) added to libraries
Diffstat (limited to 'libraries/sqlite/unix/sqlite-3.5.1/test/badutf.test')
-rw-r--r--libraries/sqlite/unix/sqlite-3.5.1/test/badutf.test143
1 files changed, 143 insertions, 0 deletions
diff --git a/libraries/sqlite/unix/sqlite-3.5.1/test/badutf.test b/libraries/sqlite/unix/sqlite-3.5.1/test/badutf.test
new file mode 100644
index 0000000..d09c933
--- /dev/null
+++ b/libraries/sqlite/unix/sqlite-3.5.1/test/badutf.test
@@ -0,0 +1,143 @@
1# 2007 May 15
2#
3# The author disclaims copyright to this source code. In place of
4# a legal notice, here is a blessing:
5#
6# May you do good and not evil.
7# May you find forgiveness for yourself and forgive others.
8# May you share freely, never taking more than you give.
9#
10#***********************************************************************
11# This file implements regression tests for SQLite library.
12#
13# This file checks to make sure SQLite is able to gracefully
14# handle malformed UTF-8.
15#
16# $Id: badutf.test,v 1.2 2007/09/12 17:01:45 danielk1977 Exp $
17
18set testdir [file dirname $argv0]
19source $testdir/tester.tcl
20
21do_test badutf-1.1 {
22 db eval {PRAGMA encoding=UTF8}
23 sqlite3_exec db {SELECT hex('%80') AS x}
24} {0 {x 80}}
25do_test badutf-1.2 {
26 sqlite3_exec db {SELECT hex('%81') AS x}
27} {0 {x 81}}
28do_test badutf-1.3 {
29 sqlite3_exec db {SELECT hex('%bf') AS x}
30} {0 {x BF}}
31do_test badutf-1.4 {
32 sqlite3_exec db {SELECT hex('%c0') AS x}
33} {0 {x C0}}
34do_test badutf-1.5 {
35 sqlite3_exec db {SELECT hex('%e0') AS x}
36} {0 {x E0}}
37do_test badutf-1.6 {
38 sqlite3_exec db {SELECT hex('%f0') AS x}
39} {0 {x F0}}
40do_test badutf-1.7 {
41 sqlite3_exec db {SELECT hex('%ff') AS x}
42} {0 {x FF}}
43
44sqlite3 db2 {}
45ifcapable utf16 {
46 do_test badutf-1.10 {
47 db2 eval {PRAGMA encoding=UTF16be}
48 sqlite3_exec db2 {SELECT hex('%80') AS x}
49 } {0 {x 0080}}
50 do_test badutf-1.11 {
51 sqlite3_exec db2 {SELECT hex('%81') AS x}
52 } {0 {x 0081}}
53 do_test badutf-1.12 {
54 sqlite3_exec db2 {SELECT hex('%bf') AS x}
55 } {0 {x 00BF}}
56 do_test badutf-1.13 {
57 sqlite3_exec db2 {SELECT hex('%c0') AS x}
58 } {0 {x FFFD}}
59 do_test badutf-1.14 {
60 sqlite3_exec db2 {SELECT hex('%c1') AS x}
61 } {0 {x FFFD}}
62 do_test badutf-1.15 {
63 sqlite3_exec db2 {SELECT hex('%c0%bf') AS x}
64 } {0 {x FFFD}}
65 do_test badutf-1.16 {
66 sqlite3_exec db2 {SELECT hex('%c1%bf') AS x}
67 } {0 {x FFFD}}
68 do_test badutf-1.17 {
69 sqlite3_exec db2 {SELECT hex('%c3%bf') AS x}
70 } {0 {x 00FF}}
71 do_test badutf-1.18 {
72 sqlite3_exec db2 {SELECT hex('%e0') AS x}
73 } {0 {x FFFD}}
74 do_test badutf-1.19 {
75 sqlite3_exec db2 {SELECT hex('%f0') AS x}
76 } {0 {x FFFD}}
77 do_test badutf-1.20 {
78 sqlite3_exec db2 {SELECT hex('%ff') AS x}
79 } {0 {x FFFD}}
80}
81
82
83ifcapable bloblit {
84 do_test badutf-2.1 {
85 sqlite3_exec db {SELECT '%80'=CAST(x'80' AS text) AS x}
86 } {0 {x 1}}
87 do_test badutf-2.2 {
88 sqlite3_exec db {SELECT CAST('%80' AS blob)=x'80' AS x}
89 } {0 {x 1}}
90}
91
92do_test badutf-3.1 {
93 sqlite3_exec db {SELECT length('%80') AS x}
94} {0 {x 1}}
95do_test badutf-3.2 {
96 sqlite3_exec db {SELECT length('%61%62%63') AS x}
97} {0 {x 3}}
98do_test badutf-3.3 {
99 sqlite3_exec db {SELECT length('%7f%80%81') AS x}
100} {0 {x 3}}
101do_test badutf-3.4 {
102 sqlite3_exec db {SELECT length('%61%c0') AS x}
103} {0 {x 2}}
104do_test badutf-3.5 {
105 sqlite3_exec db {SELECT length('%61%c0%80%80%80%80%80%80%80%80%80%80') AS x}
106} {0 {x 2}}
107do_test badutf-3.6 {
108 sqlite3_exec db {SELECT length('%c0%80%80%80%80%80%80%80%80%80%80') AS x}
109} {0 {x 1}}
110do_test badutf-3.7 {
111 sqlite3_exec db {SELECT length('%80%80%80%80%80%80%80%80%80%80') AS x}
112} {0 {x 10}}
113do_test badutf-3.8 {
114 sqlite3_exec db {SELECT length('%80%80%80%80%80%f0%80%80%80%80') AS x}
115} {0 {x 6}}
116do_test badutf-3.9 {
117 sqlite3_exec db {SELECT length('%80%80%80%80%80%f0%80%80%80%ff') AS x}
118} {0 {x 7}}
119
120do_test badutf-4.1 {
121 sqlite3_exec db {SELECT hex(trim('%80%80%80%f0%80%80%80%ff','%80%ff')) AS x}
122} {0 {x F0}}
123do_test badutf-4.2 {
124 sqlite3_exec db {SELECT hex(ltrim('%80%80%80%f0%80%80%80%ff','%80%ff')) AS x}
125} {0 {x F0808080FF}}
126do_test badutf-4.3 {
127 sqlite3_exec db {SELECT hex(rtrim('%80%80%80%f0%80%80%80%ff','%80%ff')) AS x}
128} {0 {x 808080F0}}
129do_test badutf-4.4 {
130 sqlite3_exec db {SELECT hex(trim('%80%80%80%f0%80%80%80%ff','%ff%80')) AS x}
131} {0 {x 808080F0808080FF}}
132do_test badutf-4.5 {
133 sqlite3_exec db {SELECT hex(trim('%ff%80%80%f0%80%80%80%ff','%ff%80')) AS x}
134} {0 {x 80F0808080FF}}
135do_test badutf-4.6 {
136 sqlite3_exec db {SELECT hex(trim('%ff%80%f0%80%80%80%ff','%ff%80')) AS x}
137} {0 {x F0808080FF}}
138do_test badutf-4.7 {
139 sqlite3_exec db {SELECT hex(trim('%ff%80%f0%80%80%80%ff','%ff%80%80')) AS x}
140} {0 {x FF80F0808080FF}}
141
142db2 close
143finish_test