mirror of
https://github.com/sqlite/sqlite.git
synced 2025-11-08 03:22:21 +03:00
Additional test cases for tkt2822. Fix a related bug in printf(). (CVS 4624)
FossilOrigin-Name: 8f184e40ff79c3c5ef98337615f58a4a6d0249dd
This commit is contained in:
16
manifest
16
manifest
@@ -1,5 +1,5 @@
|
|||||||
C Return\san\serror\sif\sthe\suser\sattempts\sto\srename\sa\sview.\sRelated\sto\s(but\snot\sa\sfix\sfor)\s#2831.\s(CVS\s4623)
|
C Additional\stest\scases\sfor\stkt2822.\s\sFix\sa\srelated\sbug\sin\sprintf().\s(CVS\s4624)
|
||||||
D 2007-12-13T08:15:31
|
D 2007-12-13T17:50:23
|
||||||
F Makefile.arm-wince-mingw32ce-gcc ac5f7b2cef0cd850d6f755ba6ee4ab961b1fadf7
|
F Makefile.arm-wince-mingw32ce-gcc ac5f7b2cef0cd850d6f755ba6ee4ab961b1fadf7
|
||||||
F Makefile.in 0590398f62fc2c456ff4c45e9741f5a718b7e2ac
|
F Makefile.in 0590398f62fc2c456ff4c45e9741f5a718b7e2ac
|
||||||
F Makefile.linux-gcc d53183f4aa6a9192d249731c90dbdffbd2c68654
|
F Makefile.linux-gcc d53183f4aa6a9192d249731c90dbdffbd2c68654
|
||||||
@@ -129,7 +129,7 @@ F src/pager.h f504f7ae84060fee0416a853e368d3d113c3d6fa
|
|||||||
F src/parse.y a780b33ef45dd7b3272319cf91e609d6f109a31c
|
F src/parse.y a780b33ef45dd7b3272319cf91e609d6f109a31c
|
||||||
F src/pragma.c 0246032dbe681dded8710ac43eaf654eead1434e
|
F src/pragma.c 0246032dbe681dded8710ac43eaf654eead1434e
|
||||||
F src/prepare.c f811fdb6fd4a82cca673a6e1d5b041d6caf567f1
|
F src/prepare.c f811fdb6fd4a82cca673a6e1d5b041d6caf567f1
|
||||||
F src/printf.c 5732e393c45be7c09bfca9a786daef017e0066ef
|
F src/printf.c eb27822ba2eec669161409ca31279a24c26ac910
|
||||||
F src/random.c 4a22746501bf36b0a088c66e38dde5daba6a35da
|
F src/random.c 4a22746501bf36b0a088c66e38dde5daba6a35da
|
||||||
F src/select.c 14c4a8e9d784bfc4bfbb1576226f2bc0b9fbfd10
|
F src/select.c 14c4a8e9d784bfc4bfbb1576226f2bc0b9fbfd10
|
||||||
F src/server.c 087b92a39d883e3fa113cae259d64e4c7438bc96
|
F src/server.c 087b92a39d883e3fa113cae259d64e4c7438bc96
|
||||||
@@ -479,7 +479,7 @@ F test/tkt2686.test 3022db0eee8ecf501f516557c77ef1c4039399cd
|
|||||||
F test/tkt2767.test 6b02308d553d194f329a469bf5c157fe724738d4
|
F test/tkt2767.test 6b02308d553d194f329a469bf5c157fe724738d4
|
||||||
F test/tkt2817.test 709a2201a5590bf56cb97f6fb168a62282203fd1
|
F test/tkt2817.test 709a2201a5590bf56cb97f6fb168a62282203fd1
|
||||||
F test/tkt2820.test 017fdee33aaef7abc092beab6088816f1942304b
|
F test/tkt2820.test 017fdee33aaef7abc092beab6088816f1942304b
|
||||||
F test/tkt2822.test 1260ab1c84edccdb7dc27954bd555852d6877f2e
|
F test/tkt2822.test 8b1526b1e5b0d38a1a993f7828fbb81759093686
|
||||||
F test/tkt2832.test cd56dc66bb31898b7eb2146baa5bde2eb80f96fe
|
F test/tkt2832.test cd56dc66bb31898b7eb2146baa5bde2eb80f96fe
|
||||||
F test/trace.test 75ffc1b992c780d054748a656e3e7fd674f18567
|
F test/trace.test 75ffc1b992c780d054748a656e3e7fd674f18567
|
||||||
F test/trans.test b73289992b46d38d9479ecc4fdc03d8edb2413dc
|
F test/trans.test b73289992b46d38d9479ecc4fdc03d8edb2413dc
|
||||||
@@ -600,7 +600,7 @@ F www/tclsqlite.tcl 8be95ee6dba05eabcd27a9d91331c803f2ce2130
|
|||||||
F www/vdbe.tcl 87a31ace769f20d3627a64fa1fade7fed47b90d0
|
F www/vdbe.tcl 87a31ace769f20d3627a64fa1fade7fed47b90d0
|
||||||
F www/version3.tcl 890248cf7b70e60c383b0e84d77d5132b3ead42b
|
F www/version3.tcl 890248cf7b70e60c383b0e84d77d5132b3ead42b
|
||||||
F www/whentouse.tcl fc46eae081251c3c181bd79c5faef8195d7991a5
|
F www/whentouse.tcl fc46eae081251c3c181bd79c5faef8195d7991a5
|
||||||
P 2f88b9b3e3c9abc3ae4a5dcef82707dd74f8aace
|
P 19d56d997f50be81ac2baace16b7e7a1b674301a
|
||||||
R c81a64bbb6406c1577adc63cf75c1142
|
R 4b5d2fa59d2200569cc8c7fc8474c6f8
|
||||||
U danielk1977
|
U drh
|
||||||
Z edcd429ac1cef28184ff735c983803e3
|
Z 31e1271ce8ebb5157a897446124f0d35
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
19d56d997f50be81ac2baace16b7e7a1b674301a
|
8f184e40ff79c3c5ef98337615f58a4a6d0249dd
|
||||||
14
src/printf.c
14
src/printf.c
@@ -414,6 +414,13 @@ static void vxprintf(
|
|||||||
}
|
}
|
||||||
bufpt = &buf[etBUFSIZE-1];
|
bufpt = &buf[etBUFSIZE-1];
|
||||||
if( xtype==etORDINAL ){
|
if( xtype==etORDINAL ){
|
||||||
|
static const char zOrd[] = "thstndrd";
|
||||||
|
int x = longvalue % 10;
|
||||||
|
if( x>=4 || (longvalue/10)%10==1 ){
|
||||||
|
x = 0;
|
||||||
|
}
|
||||||
|
buf[etBUFSIZE-3] = zOrd[x*2];
|
||||||
|
buf[etBUFSIZE-2] = zOrd[x*2+1];
|
||||||
bufpt -= 2;
|
bufpt -= 2;
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
@@ -426,13 +433,6 @@ static void vxprintf(
|
|||||||
longvalue = longvalue/base;
|
longvalue = longvalue/base;
|
||||||
}while( longvalue>0 );
|
}while( longvalue>0 );
|
||||||
}
|
}
|
||||||
if( xtype==etORDINAL ){
|
|
||||||
static const char zOrd[] = "thstndrd";
|
|
||||||
int x = buf[etBUFSIZE-4] - '0';
|
|
||||||
if( x>=4 ) x = 0;
|
|
||||||
buf[etBUFSIZE-3] = zOrd[x*2];
|
|
||||||
buf[etBUFSIZE-2] = zOrd[x*2+1];
|
|
||||||
}
|
|
||||||
length = &buf[etBUFSIZE-1]-bufpt;
|
length = &buf[etBUFSIZE-1]-bufpt;
|
||||||
for(idx=precision-length; idx>0; idx--){
|
for(idx=precision-length; idx>0; idx--){
|
||||||
*(--bufpt) = '0'; /* Zero pad */
|
*(--bufpt) = '0'; /* Zero pad */
|
||||||
|
|||||||
@@ -13,7 +13,7 @@
|
|||||||
# ORDER BY clauses on compound SELECT statements raised by ticket
|
# ORDER BY clauses on compound SELECT statements raised by ticket
|
||||||
# #2822 have been dealt with.
|
# #2822 have been dealt with.
|
||||||
#
|
#
|
||||||
# $Id: tkt2822.test,v 1.3 2007/12/13 07:58:51 danielk1977 Exp $
|
# $Id: tkt2822.test,v 1.4 2007/12/13 17:50:23 drh Exp $
|
||||||
#
|
#
|
||||||
|
|
||||||
set testdir [file dirname $argv0]
|
set testdir [file dirname $argv0]
|
||||||
@@ -35,8 +35,20 @@ source $testdir/tester.tcl
|
|||||||
# In the third rule, the expression must exactly match one
|
# In the third rule, the expression must exactly match one
|
||||||
# of the result columns. The sequences of three rules is
|
# of the result columns. The sequences of three rules is
|
||||||
# attempted first on the left-most SELECT. If that doesn't
|
# attempted first on the left-most SELECT. If that doesn't
|
||||||
# work, we move to the right, one by one. This is not standard
|
# work, we move to the right, one by one.
|
||||||
# SQL, it is an SQLite extension.
|
#
|
||||||
|
# Rule (3) is not in standard SQL - it is an SQLite extension,
|
||||||
|
# though one copied from PostgreSQL. The rule for compound
|
||||||
|
# queries where a search is made of SELECTs to the right
|
||||||
|
# if the left-most SELECT does not match is not a part of
|
||||||
|
# standard SQL either. This extension is unique to SQLite
|
||||||
|
# as far as we know.
|
||||||
|
#
|
||||||
|
# Rule (2) was added by the changes ticket #2822. Prior to
|
||||||
|
# that changes, SQLite did not support rule (2), making it
|
||||||
|
# technically in violation of standard SQL semantics.
|
||||||
|
# No body noticed because rule (3) has the same effect as
|
||||||
|
# rule (2) except in some obscure cases.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
|
||||||
@@ -156,5 +168,164 @@ do_test tkt2822-4.2 {
|
|||||||
}
|
}
|
||||||
} {1 {1st ORDER BY term does not match any column in the result set}}
|
} {1 {1st ORDER BY term does not match any column in the result set}}
|
||||||
|
|
||||||
finish_test
|
# Tests for rule (2).
|
||||||
|
#
|
||||||
|
# The "ORDER BY b" should match the column alias (rule 2), not the
|
||||||
|
# the t3.b value (rule 3).
|
||||||
|
#
|
||||||
|
do_test tkt2822-5.1 {
|
||||||
|
execsql {
|
||||||
|
CREATE TABLE t3(a,b);
|
||||||
|
INSERT INTO t3 VALUES(1,8);
|
||||||
|
INSERT INTO t3 VALUES(9,2);
|
||||||
|
|
||||||
|
SELECT a AS b FROM t3 ORDER BY b;
|
||||||
|
}
|
||||||
|
} {1 9}
|
||||||
|
do_test tkt2822-5.2 {
|
||||||
|
# Case does not matter. b should match B
|
||||||
|
execsql {
|
||||||
|
SELECT a AS b FROM t3 ORDER BY B;
|
||||||
|
}
|
||||||
|
} {1 9}
|
||||||
|
do_test tkt2822-5.3 {
|
||||||
|
# Quoting should not matter
|
||||||
|
execsql {
|
||||||
|
SELECT a AS 'b' FROM t3 ORDER BY "B";
|
||||||
|
}
|
||||||
|
} {1 9}
|
||||||
|
do_test tkt2822-5.4 {
|
||||||
|
# Quoting should not matter
|
||||||
|
execsql {
|
||||||
|
SELECT a AS "b" FROM t3 ORDER BY [B];
|
||||||
|
}
|
||||||
|
} {1 9}
|
||||||
|
|
||||||
|
# In "ORDER BY +b" the term is now an expression rather than
|
||||||
|
# a label. It therefore matches by rule (3) instead of rule (2).
|
||||||
|
#
|
||||||
|
do_test tkt2822-5.5 {
|
||||||
|
execsql {
|
||||||
|
SELECT a AS b FROM t3 ORDER BY +b;
|
||||||
|
}
|
||||||
|
} {9 1}
|
||||||
|
|
||||||
|
# Tests for rule 2 in compound queries
|
||||||
|
#
|
||||||
|
do_test tkt2822-6.1 {
|
||||||
|
execsql {
|
||||||
|
CREATE TABLE t6a(p,q);
|
||||||
|
INSERT INTO t6a VALUES(1,8);
|
||||||
|
INSERT INTO t6a VALUES(9,2);
|
||||||
|
CREATE TABLE t6b(x,y);
|
||||||
|
INSERT INTO t6b VALUES(1,7);
|
||||||
|
INSERT INTO t6b VALUES(7,2);
|
||||||
|
|
||||||
|
SELECT p, q FROM t6a UNION ALL SELECT x, y FROM t6b ORDER BY 1, 2
|
||||||
|
}
|
||||||
|
} {1 7 1 8 7 2 9 2}
|
||||||
|
do_test tkt2822-6.2 {
|
||||||
|
execsql {
|
||||||
|
SELECT p PX, q QX FROM t6a UNION ALL SELECT x XX, y YX FROM t6b
|
||||||
|
ORDER BY PX, YX
|
||||||
|
}
|
||||||
|
} {1 7 1 8 7 2 9 2}
|
||||||
|
do_test tkt2822-6.3 {
|
||||||
|
execsql {
|
||||||
|
SELECT p PX, q QX FROM t6a UNION ALL SELECT x XX, y YX FROM t6b
|
||||||
|
ORDER BY XX, QX
|
||||||
|
}
|
||||||
|
} {1 7 1 8 7 2 9 2}
|
||||||
|
do_test tkt2822-6.4 {
|
||||||
|
execsql {
|
||||||
|
SELECT p PX, q QX FROM t6a UNION ALL SELECT x XX, y YX FROM t6b
|
||||||
|
ORDER BY QX, XX
|
||||||
|
}
|
||||||
|
} {7 2 9 2 1 7 1 8}
|
||||||
|
do_test tkt2822-6.5 {
|
||||||
|
execsql {
|
||||||
|
SELECT p PX, q QX FROM t6a UNION ALL SELECT x XX, y YX FROM t6b
|
||||||
|
ORDER BY t6b.x, QX
|
||||||
|
}
|
||||||
|
} {1 7 1 8 7 2 9 2}
|
||||||
|
do_test tkt2822-6.6 {
|
||||||
|
execsql {
|
||||||
|
SELECT p PX, q QX FROM t6a UNION ALL SELECT x XX, y YX FROM t6b
|
||||||
|
ORDER BY t6a.q, XX
|
||||||
|
}
|
||||||
|
} {7 2 9 2 1 7 1 8}
|
||||||
|
|
||||||
|
# More error message tests. This is really more of a test of the
|
||||||
|
# %r ordinal value formatting capablity added to sqlite3_snprintf()
|
||||||
|
# by ticket #2822.
|
||||||
|
#
|
||||||
|
do_test tkt2822-7.1 {
|
||||||
|
execsql {
|
||||||
|
CREATE TABLE t7(a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13,a14,
|
||||||
|
a15,a16,a17,a18,a19,a20,a21,a22,a23,a24,a25);
|
||||||
|
}
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 0;
|
||||||
|
}
|
||||||
|
} {1 {1st ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.2 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 0;
|
||||||
|
}
|
||||||
|
} {1 {2nd ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.3 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 0;
|
||||||
|
}
|
||||||
|
} {1 {3rd ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.4 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 0;
|
||||||
|
}
|
||||||
|
} {1 {4th ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.9 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 0;
|
||||||
|
}
|
||||||
|
} {1 {9th ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.10 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 0;
|
||||||
|
}
|
||||||
|
} {1 {10th ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.11 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 0;
|
||||||
|
}
|
||||||
|
} {1 {11th ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.12 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 0;
|
||||||
|
}
|
||||||
|
} {1 {12th ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.13 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 13, 0;
|
||||||
|
}
|
||||||
|
} {1 {13th ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.20 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10,
|
||||||
|
11,12,13,14,15,16,17,18,19, 0
|
||||||
|
}
|
||||||
|
} {1 {20th ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.21 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10,
|
||||||
|
11,12,13,14,15,16,17,18,19, 20, 0
|
||||||
|
}
|
||||||
|
} {1 {21st ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
do_test tkt2822-7.22 {
|
||||||
|
catchsql {
|
||||||
|
SELECT * FROM t7 ORDER BY 1, 2, 3, 4, 5, 6, 7, 8, 9, 10,
|
||||||
|
11,12,13,14,15,16,17,18,19, 20, 21, 0
|
||||||
|
}
|
||||||
|
} {1 {22nd ORDER BY term out of range - should be between 1 and 25}}
|
||||||
|
|
||||||
|
|
||||||
|
finish_test
|
||||||
|
|||||||
Reference in New Issue
Block a user