Implement the SQLTester's result escaping rules.
FossilOrigin-Name: 61bb950873a1ec45a71b15a0ab5128a50417c4ecdd7d5bd9add0c18afcbadf34
This commit is contained in:
parent
5158a9a9a7
commit
4340f27e17
@ -1120,7 +1120,7 @@ JNIEXPORT jstring JNICALL Java_org_sqlite_jni_SQLite3Jni_sqlite3_1db_1filename
|
|||||||
* Method: sqlite3_db_config
|
* Method: sqlite3_db_config
|
||||||
* Signature: (Lorg/sqlite/jni/sqlite3;ILorg/sqlite/jni/OutputPointer/Int32;)I
|
* Signature: (Lorg/sqlite/jni/sqlite3;ILorg/sqlite/jni/OutputPointer/Int32;)I
|
||||||
*/
|
*/
|
||||||
JNIEXPORT jint JNICALL Java_org_sqlite_jni_SQLite3Jni_sqlite3_1db_1config__Lorg_sqlite_jni_sqlite3_2ILorg_sqlite_jni_OutputPointer_00024Int32_2
|
JNIEXPORT jint JNICALL Java_org_sqlite_jni_SQLite3Jni_sqlite3_1db_1config__Lorg_sqlite_jni_sqlite3_2ILorg_sqlite_jni_OutputPointer_Int32_2
|
||||||
(JNIEnv *, jclass, jobject, jint, jobject);
|
(JNIEnv *, jclass, jobject, jint, jobject);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -17,6 +17,7 @@ import java.util.List;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.nio.charset.StandardCharsets;
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.regex.*;
|
||||||
import org.sqlite.jni.*;
|
import org.sqlite.jni.*;
|
||||||
import static org.sqlite.jni.SQLite3Jni.*;
|
import static org.sqlite.jni.SQLite3Jni.*;
|
||||||
|
|
||||||
@ -263,9 +264,38 @@ public class SQLTester {
|
|||||||
|
|
||||||
void incrementTestCounter(){ ++nTest; ++nTotalTest; }
|
void incrementTestCounter(){ ++nTest; ++nTotalTest; }
|
||||||
|
|
||||||
|
static final Pattern patternPlain = Pattern.compile("[\\W]", Pattern.MULTILINE);
|
||||||
|
static final Pattern patternSquiggly = Pattern.compile("[{}]", Pattern.MULTILINE);
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns v or some escaped form of v, as defined in the tester's
|
||||||
|
spec doc.
|
||||||
|
*/
|
||||||
String escapeSqlValue(String v){
|
String escapeSqlValue(String v){
|
||||||
// TODO: implement the escaping rules
|
Matcher m = patternPlain.matcher(v);
|
||||||
return v;
|
if( !m.find() ){
|
||||||
|
return v /* no escaping needed */;
|
||||||
|
}
|
||||||
|
m = patternSquiggly.matcher(v);
|
||||||
|
if( !m.find() ){
|
||||||
|
return "{"+v+"}";
|
||||||
|
}
|
||||||
|
final StringBuilder sb = new StringBuilder("\"");
|
||||||
|
final int n = v.length();
|
||||||
|
for(int i = 0; i < n; ++i){
|
||||||
|
final char ch = v.charAt(i);
|
||||||
|
switch(ch){
|
||||||
|
case '\\': sb.append("\\\\"); break;
|
||||||
|
case '"': sb.append("\\\""); break;
|
||||||
|
default:
|
||||||
|
//verbose("CHAR ",(int)ch," ",ch," octal=",String.format("\\%03o", (int)ch));
|
||||||
|
if( (int)ch < 32 ) sb.append(String.format("\\%03o", (int)ch));
|
||||||
|
else sb.append(ch);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
sb.append("\"");
|
||||||
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void appendDbErr(sqlite3 db, StringBuilder sb, int rc){
|
private void appendDbErr(sqlite3 db, StringBuilder sb, int rc){
|
||||||
@ -327,12 +357,12 @@ public class SQLTester {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
switch(appendMode){
|
switch(appendMode){
|
||||||
case ESCAPED:
|
|
||||||
sb.append( escapeSqlValue(val) );
|
|
||||||
break;
|
|
||||||
case ASIS:
|
case ASIS:
|
||||||
sb.append( val );
|
sb.append( val );
|
||||||
break;
|
break;
|
||||||
|
case ESCAPED:
|
||||||
|
sb.append( escapeSqlValue(val) );
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
Util.toss(RuntimeException.class, "Unhandled ResultBufferMode.");
|
Util.toss(RuntimeException.class, "Unhandled ResultBufferMode.");
|
||||||
}
|
}
|
||||||
@ -619,7 +649,7 @@ class ResultCommand extends Command {
|
|||||||
int rc = t.execSql(null, true, bufferMode, ResultRowMode.ONELINE, sql);
|
int rc = t.execSql(null, true, bufferMode, ResultRowMode.ONELINE, sql);
|
||||||
final String result = t.getResultText().trim();
|
final String result = t.getResultText().trim();
|
||||||
final String sArgs = argv.length>1 ? Util.argvToString(argv) : "";
|
final String sArgs = argv.length>1 ? Util.argvToString(argv) : "";
|
||||||
//t.verbose(argv[0]," rc = ",rc," result buffer:\n", result,"\nargs:\n",sArgs);
|
t.verbose(argv[0]," result buffer:\n", result,"\nargs:\n",sArgs);
|
||||||
if( !result.equals(sArgs) ){
|
if( !result.equals(sArgs) ){
|
||||||
Util.toss(TestFailure.class, argv[0]," comparison failed.");
|
Util.toss(TestFailure.class, argv[0]," comparison failed.");
|
||||||
}
|
}
|
||||||
@ -658,13 +688,15 @@ class TableResultCommand extends Command {
|
|||||||
int n = content.length();
|
int n = content.length();
|
||||||
content = content.substring(0, n-6);
|
content = content.substring(0, n-6);
|
||||||
}
|
}
|
||||||
final String[] globs = content.split("\s*\n\s*");
|
final String[] globs = content.split("\\s*\\n\\s*");
|
||||||
if( globs.length < 1 ){
|
if( globs.length < 1 ){
|
||||||
Util.toss(TestFailure.class, argv[0], " requires 1 or more ",
|
Util.toss(TestFailure.class, argv[0], " requires 1 or more ",
|
||||||
(jsonMode ? "json snippets" : "globs"),".");
|
(jsonMode ? "json snippets" : "globs"),".");
|
||||||
}
|
}
|
||||||
final String sql = t.takeInputBuffer();
|
final String sql = t.takeInputBuffer();
|
||||||
t.execSql(null, true, ResultBufferMode.ESCAPED, ResultRowMode.NEWLINE, sql);
|
t.execSql(null, true,
|
||||||
|
jsonMode ? ResultBufferMode.ASIS : ResultBufferMode.ESCAPED,
|
||||||
|
ResultRowMode.NEWLINE, sql);
|
||||||
final String rbuf = t.getResultText();
|
final String rbuf = t.getResultText();
|
||||||
final String[] res = rbuf.split("\n");
|
final String[] res = rbuf.split("\n");
|
||||||
if( res.length != globs.length ){
|
if( res.length != globs.length ){
|
||||||
@ -672,7 +704,8 @@ class TableResultCommand extends Command {
|
|||||||
res.length," row(s) but expecting ",globs.length);
|
res.length," row(s) but expecting ",globs.length);
|
||||||
}
|
}
|
||||||
for(int i = 0; i < res.length; ++i){
|
for(int i = 0; i < res.length; ++i){
|
||||||
final String glob = GlobCommand.globToStrglob(globs[i]).replaceAll("\s+"," ");
|
final String glob = GlobCommand.globToStrglob(globs[i])
|
||||||
|
.replaceAll("\\s+"," ");
|
||||||
//t.verbose(argv[0]," <<",glob,">> vs <<",res[i],">>");
|
//t.verbose(argv[0]," <<",glob,">> vs <<",res[i],">>");
|
||||||
if( jsonMode ){
|
if( jsonMode ){
|
||||||
if( !glob.equals(res[i]) ){
|
if( !glob.equals(res[i]) ){
|
||||||
|
@ -241,7 +241,7 @@ by that argument.
|
|||||||
|
|
||||||
The --json and --json-block commands work like --result and --tableresult,
|
The --json and --json-block commands work like --result and --tableresult,
|
||||||
respectively. The difference is that column values are appended to the
|
respectively. The difference is that column values are appended to the
|
||||||
result buffer literally, without every enclosing the values in `{...}` or
|
result buffer literally, without ever enclosing the values in `{...}` or
|
||||||
`"..."` and without escaping any characters in the column value and comparison
|
`"..."` and without escaping any characters in the column value and comparison
|
||||||
is always an exact strcmp() not a GLOB.
|
is always an exact strcmp() not a GLOB.
|
||||||
|
|
||||||
|
@ -23,9 +23,11 @@ This is from the print command's body.
|
|||||||
Also from the print command.
|
Also from the print command.
|
||||||
--- also ignored
|
--- also ignored
|
||||||
--testcase 1
|
--testcase 1
|
||||||
SELECT 'a', 'b';
|
SELECT 'a b', 'c';
|
||||||
SELECT 'a', 'b';
|
SELECT 'd', 'e';
|
||||||
--result a b a b
|
SELECT '{}', 'f';
|
||||||
|
SELECT '{ }', 'g'
|
||||||
|
--result {a b} c d e "{}" f "{\011}" g
|
||||||
--testcase 2
|
--testcase 2
|
||||||
SELECT 123
|
SELECT 123
|
||||||
--glob ###
|
--glob ###
|
||||||
|
18
manifest
18
manifest
@ -1,5 +1,5 @@
|
|||||||
C Add\s--json\sand\s--json-block\sSQLTester\scommands.
|
C Implement\sthe\sSQLTester's\sresult\sescaping\srules.
|
||||||
D 2023-08-09T13:51:50.893
|
D 2023-08-09T14:24:22.127
|
||||||
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
|
F .fossil-settings/empty-dirs dbb81e8fc0401ac46a1491ab34a7f2c7c0452f2f06b54ebb845d024ca8283ef1
|
||||||
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
|
F .fossil-settings/ignore-glob 35175cdfcf539b2318cb04a9901442804be81cd677d8b889fcc9149c21f239ea
|
||||||
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
|
F LICENSE.md df5091916dbb40e6e9686186587125e1b2ff51f022cc334e886c19a0e9982724
|
||||||
@ -233,7 +233,7 @@ F ext/icu/sqliteicu.h fa373836ed5a1ee7478bdf8a1650689294e41d0c89c1daab26e9ae78a3
|
|||||||
F ext/jni/GNUmakefile 52f402abb8c4695a58f734d20455cf1a5afaaa10ceacc47bcbf1b06a8d5d27e8
|
F ext/jni/GNUmakefile 52f402abb8c4695a58f734d20455cf1a5afaaa10ceacc47bcbf1b06a8d5d27e8
|
||||||
F ext/jni/README.md e965674505e105626127ad45e628e4d19fcd379cdafc4d23c814c1ac2c55681d
|
F ext/jni/README.md e965674505e105626127ad45e628e4d19fcd379cdafc4d23c814c1ac2c55681d
|
||||||
F ext/jni/src/c/sqlite3-jni.c 07871efe50bb090023259c95df8b851c617917f762b60a3460c9778b2ae6356b
|
F ext/jni/src/c/sqlite3-jni.c 07871efe50bb090023259c95df8b851c617917f762b60a3460c9778b2ae6356b
|
||||||
F ext/jni/src/c/sqlite3-jni.h ec38592e88d32f09ba4bde13f2e135bb7cf8712356b807df521b3fc99edeab32
|
F ext/jni/src/c/sqlite3-jni.h 103ecb1e9213e904f7ba7f955fe305587f5f0cd55290636832f639b81270b5f6
|
||||||
F ext/jni/src/org/sqlite/jni/Authorizer.java 1308988f7f40579ea0e4deeaec3c6be971630566bd021c31367fe3f5140db892
|
F ext/jni/src/org/sqlite/jni/Authorizer.java 1308988f7f40579ea0e4deeaec3c6be971630566bd021c31367fe3f5140db892
|
||||||
F ext/jni/src/org/sqlite/jni/AutoExtension.java 3409ad8954d6466bf772e6be9379e0e337312b446b668287062845755a16844d
|
F ext/jni/src/org/sqlite/jni/AutoExtension.java 3409ad8954d6466bf772e6be9379e0e337312b446b668287062845755a16844d
|
||||||
F ext/jni/src/org/sqlite/jni/BusyHandler.java 1b1d3e5c86cd796a0580c81b6af6550ad943baa25e47ada0dcca3aff3ebe978c
|
F ext/jni/src/org/sqlite/jni/BusyHandler.java 1b1d3e5c86cd796a0580c81b6af6550ad943baa25e47ada0dcca3aff3ebe978c
|
||||||
@ -266,10 +266,10 @@ F ext/jni/src/org/sqlite/jni/sqlite3_context.java d26573fc7b309228cb49786e907859
|
|||||||
F ext/jni/src/org/sqlite/jni/sqlite3_stmt.java 78e6d1b95ac600a9475e9db4623f69449322b0c93d1bd4e1616e76ed547ed9fc
|
F ext/jni/src/org/sqlite/jni/sqlite3_stmt.java 78e6d1b95ac600a9475e9db4623f69449322b0c93d1bd4e1616e76ed547ed9fc
|
||||||
F ext/jni/src/org/sqlite/jni/sqlite3_value.java 3d1d4903e267bc0bc81d57d21f5e85978eff389a1a6ed46726dbe75f85e6914a
|
F ext/jni/src/org/sqlite/jni/sqlite3_value.java 3d1d4903e267bc0bc81d57d21f5e85978eff389a1a6ed46726dbe75f85e6914a
|
||||||
F ext/jni/src/org/sqlite/jni/tester/Outer.java 3d9c40f8ed58ec0df05ca160986ea06ec84ec1f338b069cfba9604bbba467a01
|
F ext/jni/src/org/sqlite/jni/tester/Outer.java 3d9c40f8ed58ec0df05ca160986ea06ec84ec1f338b069cfba9604bbba467a01
|
||||||
F ext/jni/src/org/sqlite/jni/tester/SQLTester.java 41f48e3d4834e08bf35e21f8c62b8350c61161aafb498e4961c642194c06a29d
|
F ext/jni/src/org/sqlite/jni/tester/SQLTester.java f21b90075f70d0f2550847424fc4cfc7ab80ef930b97a02f4e032150f3a7e8a7
|
||||||
F ext/jni/src/org/sqlite/jni/tester/TestScript.java f2a87c88ab23fa4601a985eb69bdc8b4f81cabfab04fdc3544ecefde207e08d4
|
F ext/jni/src/org/sqlite/jni/tester/TestScript.java f2a87c88ab23fa4601a985eb69bdc8b4f81cabfab04fdc3544ecefde207e08d4
|
||||||
F ext/jni/src/org/sqlite/jni/tester/test-script-interpreter.md ae1d6706f723517e03a04ab578a539fa3df66fe38adad113f10b61eabc524d09
|
F ext/jni/src/org/sqlite/jni/tester/test-script-interpreter.md 480825a33a4d8df19aac8d6012b1041e0f679198a0ce9fbf189363e8167b51b1
|
||||||
F ext/jni/src/tests/000_first.test ea6ac62e13a3787f3f6d402fa5e9c7a7e85b43ec11ce10e260d673be7ecc537b
|
F ext/jni/src/tests/000_first.test c9132e01fbb050af57db2f8018f99e7084b61557afd56107eeb830e84f8ad852
|
||||||
F ext/jni/src/tests/010_ignored.test e17e874c6ab3c437f1293d88093cf06286083b65bf162317f91bbfd92f961b70
|
F ext/jni/src/tests/010_ignored.test e17e874c6ab3c437f1293d88093cf06286083b65bf162317f91bbfd92f961b70
|
||||||
F ext/lsm1/Makefile a553b728bba6c11201b795188c5708915cc4290f02b7df6ba7e8c4c943fd5cd9
|
F ext/lsm1/Makefile a553b728bba6c11201b795188c5708915cc4290f02b7df6ba7e8c4c943fd5cd9
|
||||||
F ext/lsm1/Makefile.msc f8c878b467232226de288da320e1ac71c131f5ec91e08b21f502303347260013
|
F ext/lsm1/Makefile.msc f8c878b467232226de288da320e1ac71c131f5ec91e08b21f502303347260013
|
||||||
@ -2090,8 +2090,8 @@ F vsixtest/vsixtest.tcl 6a9a6ab600c25a91a7acc6293828957a386a8a93
|
|||||||
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
|
F vsixtest/vsixtest.vcxproj.data 2ed517e100c66dc455b492e1a33350c1b20fbcdc
|
||||||
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
|
F vsixtest/vsixtest.vcxproj.filters 37e51ffedcdb064aad6ff33b6148725226cd608e
|
||||||
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
|
F vsixtest/vsixtest_TemporaryKey.pfx e5b1b036facdb453873e7084e1cae9102ccc67a0
|
||||||
P 8c5b6d893df4a4e82c6d8e07507fc160b11412ede4bb903ff4e3f5ffa59a9cb9
|
P 478129d901824e675d86494044f73c313532e9f80e7ee6f425474df8237a82f5
|
||||||
R 90d3df2a48743fa4d0421d9f7ba4a451
|
R 03dd2e2f7f4ef00e6ca61e5373fcfe05
|
||||||
U stephan
|
U stephan
|
||||||
Z 0acfbb2c69aeffb3bdb56736e07c0e08
|
Z 5d907161d89ca6745e892ceb9fdce9a9
|
||||||
# Remove this line to create a well-formed Fossil manifest.
|
# Remove this line to create a well-formed Fossil manifest.
|
||||||
|
@ -1 +1 @@
|
|||||||
478129d901824e675d86494044f73c313532e9f80e7ee6f425474df8237a82f5
|
61bb950873a1ec45a71b15a0ab5128a50417c4ecdd7d5bd9add0c18afcbadf34
|
Loading…
Reference in New Issue
Block a user