rtreeH.test 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. # 2018-05-16
  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 contains tests for the r-tree module, specifically the
  12. # auxiliary column mechanism.
  13. if {![info exists testdir]} {
  14. set testdir [file join [file dirname [info script]] .. .. test]
  15. }
  16. source [file join [file dirname [info script]] rtree_util.tcl]
  17. source $testdir/tester.tcl
  18. ifcapable !rtree { finish_test ; return }
  19. do_execsql_test rtreeH-100 {
  20. CREATE VIRTUAL TABLE t1 USING rtree(id,x0,x1,y0,y1,+label,+other);
  21. INSERT INTO t1(x0,x1,y0,y1,label) VALUES
  22. (0,10,0,10,'lower-left corner'),
  23. (0,10,90,100,'upper-left corner'),
  24. (90,100,0,10,'lower-right corner'),
  25. (90,100,90,100,'upper-right corner'),
  26. (40,60,40,60,'center'),
  27. (0,5,0,100,'left edge'),
  28. (95,100,0,100,'right edge'),
  29. (0,100,0,5,'bottom edge'),
  30. (0,100,95,100,'top edge'),
  31. (0,100,0,100,'the whole thing'),
  32. (0,50,0,100,'left half'),
  33. (51,100,0,100,'right half'),
  34. (0,100,0,50,'bottom half'),
  35. (0,100,51,100,'top half');
  36. } {}
  37. do_execsql_test rtreeH-101 {
  38. SELECT * FROM t1_rowid ORDER BY rowid
  39. } {1 1 {lower-left corner} {} 2 1 {upper-left corner} {} 3 1 {lower-right corner} {} 4 1 {upper-right corner} {} 5 1 center {} 6 1 {left edge} {} 7 1 {right edge} {} 8 1 {bottom edge} {} 9 1 {top edge} {} 10 1 {the whole thing} {} 11 1 {left half} {} 12 1 {right half} {} 13 1 {bottom half} {} 14 1 {top half} {}}
  40. do_execsql_test rtreeH-102 {
  41. SELECT * FROM t1 WHERE rowid=5;
  42. } {5 40.0 60.0 40.0 60.0 center {}}
  43. do_execsql_test rtreeH-102b {
  44. SELECT * FROM t1 WHERE rowid=5.0;
  45. } {5 40.0 60.0 40.0 60.0 center {}}
  46. do_execsql_test rtreeH-102c {
  47. SELECT * FROM t1 WHERE rowid='5';
  48. } {5 40.0 60.0 40.0 60.0 center {}}
  49. do_execsql_test rtreeH-102d {
  50. SELECT * FROM t1 WHERE rowid='0005';
  51. } {5 40.0 60.0 40.0 60.0 center {}}
  52. do_execsql_test rtreeH-102e {
  53. SELECT * FROM t1 WHERE rowid='+5.0e+0';
  54. } {5 40.0 60.0 40.0 60.0 center {}}
  55. do_execsql_test rtreeH-103 {
  56. SELECT * FROM t1 WHERE label='center';
  57. } {5 40.0 60.0 40.0 60.0 center {}}
  58. do_execsql_test rtreeH-104 {
  59. SELECT * FROM t1 WHERE rowid='+5.0e+0x';
  60. } {}
  61. do_execsql_test rtreeH-105 {
  62. SELECT * FROM t1 WHERE rowid=x'35';
  63. } {}
  64. do_execsql_test rtreeH-106 {
  65. SELECT * FROM t1 WHERE rowid=null;
  66. } {}
  67. do_rtree_integrity_test rtreeH-110 t1
  68. do_execsql_test rtreeH-120 {
  69. SELECT label FROM t1 WHERE x1<=50 ORDER BY id
  70. } {{lower-left corner} {upper-left corner} {left edge} {left half}}
  71. do_execsql_test rtreeH-121 {
  72. SELECT label FROM t1 WHERE x1<=50 AND label NOT LIKE '%corner%' ORDER BY id
  73. } {{left edge} {left half}}
  74. do_execsql_test rtreeH-200 {
  75. WITH RECURSIVE
  76. c1(x) AS (VALUES(0) UNION ALL SELECT x+1 FROM c1 WHERE x<99),
  77. c2(y) AS (VALUES(0) UNION ALL SELECT y+1 FROM c2 WHERE y<99)
  78. INSERT INTO t1(id, x0,x1,y0,y1,label)
  79. SELECT 1000+x+y*100, x, x+1, y, y+1, printf('box-%d,%d',x,y) FROM c1, c2;
  80. } {}
  81. do_execsql_test rtreeH-210 {
  82. SELECT label FROM t1 WHERE x0>=48 AND x1<=50 AND y0>=48 AND y1<=50
  83. ORDER BY id;
  84. } {box-48,48 box-49,48 box-48,49 box-49,49}
  85. do_execsql_test rtreeH-300 {
  86. UPDATE t1 SET label='x'||label
  87. WHERE x0>=49 AND x1<=50 AND y0>=49 AND y1<=50;
  88. SELECT label FROM t1 WHERE x0>=48 AND x1<=50 AND y0>=48 AND y1<=50
  89. ORDER BY id;
  90. } {box-48,48 box-49,48 box-48,49 xbox-49,49}
  91. finish_test