Linux ns1.utparral.edu.mx 6.8.0-79-generic #79~22.04.1-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 15 16:54:53 UTC 2 x86_64
Apache/2.4.58 (Unix) OpenSSL/1.1.1w PHP/8.2.12 mod_perl/2.0.12 Perl/v5.34.1
: 10.10.1.9 | : 10.10.1.254
Cant Read [ /etc/named.conf ]
daemon
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
README
+ Create Folder
+ Create File
/
opt /
lampp /
lib /
php /
test /
Pager /
tests /
[ HOME SHELL ]
Name
Size
Permission
Action
all_tests.php
643
B
-rw-r--r--
multibyte_post.php
1.35
KB
-rw-r--r--
pager_include.php
104
B
-rw-r--r--
pager_jumping_noData_test.php
1.05
KB
-rw-r--r--
pager_jumping_test.php
3.2
KB
-rw-r--r--
pager_jumping_tests.php
554
B
-rw-r--r--
pager_noData_test.php
1.39
KB
-rw-r--r--
pager_post_test.php
2.2
KB
-rw-r--r--
pager_post_test_simple.php
1.22
KB
-rw-r--r--
pager_post_tests.php
331
B
-rw-r--r--
pager_sliding_noData_test.php
846
B
-rw-r--r--
pager_sliding_notExpanded_test.php
1.73
KB
-rw-r--r--
pager_sliding_test.php
1.84
KB
-rw-r--r--
pager_sliding_tests.php
621
B
-rw-r--r--
pager_test.php
30.17
KB
-rw-r--r--
pager_tests.php
508
B
-rw-r--r--
pager_test_xss.php
1.27
KB
-rw-r--r--
pager_wrapper_include.php
146
B
-rw-r--r--
pager_wrapper_test.php
8.86
KB
-rw-r--r--
README
248
B
-rw-r--r--
simple_include.php
495
B
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : pager_wrapper_test.php
<?php // $Id: pager_wrapper_test.php,v 1.3 2006/12/12 17:25:50 quipo Exp $ require_once 'simple_include.php'; require_once 'pager_wrapper_include.php'; class TestOfPagerWrapper extends UnitTestCase { function TestOfPagerWrapper($name='Test of Pager_Wrapper') { $this->UnitTestCase($name); } function setUp() { } function tearDown() { } /** * Basic tests for rewriteCountQuery() */ function testRewriteCountQuery() { //test LIMIT $query = 'SELECT a, b, c, d FROM mytable WHERE a=1 AND c="g" LIMIT 2'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertEqual($expected, rewriteCountQuery($query)); //test ORDER BY and quotes $query = 'SELECT a, b, c, d FROM mytable WHERE a=1 AND c="g" ORDER BY (a, b)'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertEqual($expected, rewriteCountQuery($query)); //test CR/LF $query = 'SELECT a, b, c, d FROM mytable WHERE a=1 AND c="g" ORDER BY (a, b)'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertEqual($expected, rewriteCountQuery($query)); //test GROUP BY $query = 'SELECT a, b, c, d FROM mytable WHERE a=1 GROUP BY c'; $this->assertFalse(rewriteCountQuery($query)); //test DISTINCT $query = 'SELECT DISTINCT a, b, c, d FROM mytable WHERE a=1 GROUP BY c'; $this->assertFalse(rewriteCountQuery($query)); //test UNION $query = 'SELECT a FROM mytable1 UNION SELECT a FROM mytable2'; $this->assertFalse(rewriteCountQuery($query)); //test MiXeD Keyword CaSe $query = 'SELECT a, b, c, d from mytable WHERE a=1 AND c="g"'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertEqual($expected, rewriteCountQuery($query)); //test function speed... this query used to be very slow to parse $query = "SELECT i.item_id, ia.addition, u.username, i.date_created, i.start_date, i.expiry_date FROM item i, item_addition ia, item_type it, item_type_mapping itm, usr u, category c WHERE ia.item_type_mapping_id = itm.item_type_mapping_id AND i.updated_by_id = u.usr_id AND it.item_type_id = itm.item_type_id AND i.item_id = ia.item_id AND i.item_type_id = it.item_type_id AND itm.field_name = 'title' AND it.item_type_id = 2 AND i.category_id = 1 AND i.status = 4 AND i.category_id = c.category_id AND 0 NOT IN (COALESCE(c.perms, '-1')) ORDER BY i.last_updated DESC"; $expected = "SELECT COUNT(*) FROM item i, item_addition ia, item_type it, item_type_mapping itm, usr u, category c WHERE ia.item_type_mapping_id = itm.item_type_mapping_id AND i.updated_by_id = u.usr_id AND it.item_type_id = itm.item_type_id AND i.item_id = ia.item_id AND i.item_type_id = it.item_type_id AND itm.field_name = 'title' AND it.item_type_id = 2 AND i.category_id = 1 AND i.status = 4 AND i.category_id = c.category_id AND 0 NOT IN (COALESCE(c.perms, '-1'))"; $this->assertEqual($expected, rewriteCountQuery($query)); } /** * Test rewriteCountQuery() with queries having a subquery in the SELECT clause */ function testRewriteCountQuery_SubqueriesInSelectClause() { $query = 'SELECT a, (SELECT a FROM b) AS b, c, d FROM mytable WHERE a=1 AND c="g" LIMIT 2'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertFalse(rewriteCountQuery($query)); $query = 'SELECT a, (SELECT a FROM b) AS b, (SELECT c FROM c) AS c, d FROM mytable WHERE a=1 AND c="g" LIMIT 2'; //$expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertFalse(rewriteCountQuery($query)); $query = 'SELECT `id`, `ip`, ( SELECT TIMEDIFF(MAX(P.`time`), MIN(P.`time`)) FROM `przejscia` as P WHERE P.`id_wejscia`=W.`id` ) as `czas` FROM `wejscia` as W WHERE W.id_domeny=? ORDER BY W.czas_wejscia DESC'; $expected = 'SELECT COUNT(*) FROM `wejscia` as W WHERE W.id_domeny=? ORDER BY W.czas_wejscia DESC'; $this->assertFalse(rewriteCountQuery($query)); } /** * Test rewriteCountQuery() with queries having a subquery in the FROM clause */ function testRewriteCountQuery_SubqueriesInFromClause() { $query = 'SELECT a, b, c, d FROM (SELECT a, b, c, d FROM mytable WHERE a=1) AS tbl_alias WHERE a=1'; $expected = 'SELECT COUNT(*) FROM (SELECT a, b, c, d FROM mytable WHERE a=1) AS tbl_alias WHERE a=1'; $this->assertEqual($expected, rewriteCountQuery($query)); } /** * Test rewriteCountQuery() with queries having a subquery in the WHERE clause */ function testRewriteCountQuery_SubqueriesInWhereClause() { //this one is not rewritten: subqueries with ORDER BY clauses might get truncated $query = 'SELECT Version.VersionId, Version.Identifier,News.* FROM VersionBroker JOIN ObjectType ON ObjectType.ObjectTypeId = VersionBroker.ObjectTypeId JOIN Version ON VersionBroker.Identifier = Version.Identifier JOIN News ON Version.ObjectId = News.NewsId WHERE Version.Status = \'Approved\' AND ObjectType.Name = \'News\' AND Version.ApprovedTS = ( SELECT SubV.ApprovedTS FROM Version SubV WHERE SubV.Identifier = VersionBroker.Identifier ORDER BY ApprovedTS DESC LIMIT 1) ORDER BY ApprovedTS DESC'; $expected = 'SELECT COUNT(*) FROM VersionBroker JOIN ObjectType ON ObjectType.ObjectTypeId = VersionBroker.ObjectTypeId JOIN Version ON VersionBroker.Identifier = Version.Identifier JOIN News ON Version.ObjectId = News.NewsId WHERE Version.Status = \'Approved\' AND ObjectType.Name = \'News\' AND Version.ApprovedTS = ( SELECT SubV.ApprovedTS FROM Version SubV WHERE SubV.Identifier = VersionBroker.Identifier ORDER BY ApprovedTS DESC LIMIT 1) ORDER BY ApprovedTS DESC'; //$this->assertEqual($expected, rewriteCountQuery($query)); $this->assertFalse(rewriteCountQuery($query)); //this one should pass... subquery without ORDER BY or LIMIT clause $query = 'SELECT Version.VersionId, Version.Identifier,News.* FROM VersionBroker JOIN ObjectType ON ObjectType.ObjectTypeId = VersionBroker.ObjectTypeId JOIN Version ON VersionBroker.Identifier = Version.Identifier JOIN News ON Version.ObjectId = News.NewsId WHERE Version.Status = \'Approved\' AND ObjectType.Name = \'News\' AND Version.ApprovedTS = ( SELECT SubV.ApprovedTS FROM Version SubV WHERE SubV.Identifier = VersionBroker.Identifier ) ORDER BY ApprovedTS DESC'; $expected = 'SELECT COUNT(*) FROM VersionBroker JOIN ObjectType ON ObjectType.ObjectTypeId = VersionBroker.ObjectTypeId JOIN Version ON VersionBroker.Identifier = Version.Identifier JOIN News ON Version.ObjectId = News.NewsId WHERE Version.Status = \'Approved\' AND ObjectType.Name = \'News\' AND Version.ApprovedTS = ( SELECT SubV.ApprovedTS FROM Version SubV WHERE SubV.Identifier = VersionBroker.Identifier )'; $this->assertEqual($expected, rewriteCountQuery($query)); } /** * Test rewriteCountQuery() with queries having keywords embedded in other words */ function testRewriteCountQuery_EmbeddedKeywords() { $query = 'SELECT afieldFROM, b, c, d FROM mytable WHERE a=1 AND c="g"'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertEqual($expected, rewriteCountQuery($query)); $query = 'SELECT FROMafield, b, c, d FROM mytable WHERE a=1 AND c="g"'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertEqual($expected, rewriteCountQuery($query)); $query = 'SELECT afieldFROMaaa, b, c, d FROM mytable WHERE a=1 AND c="gLIMIT"'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="gLIMIT"'; $this->assertEqual($expected, rewriteCountQuery($query)); $query = 'SELECT DISTINCTaaa, b, c, d FROM mytable WHERE a=1 AND c="g"'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g"'; $this->assertEqual($expected, rewriteCountQuery($query)); //this one fails... the regexp should NOT match keywords within quotes. //we need a full blown stack-based parser to catch this... $query = 'SELECT afieldFROMaaa, b, c, d FROM mytable WHERE a=1 AND c="g LIMIT a"'; $expected = 'SELECT COUNT(*) FROM mytable WHERE a=1 AND c="g LIMIT a"'; $this->assertEqual($expected, rewriteCountQuery($query)); } } if (!defined('TEST_RUNNING')) { define('TEST_RUNNING', true); $test = &new TestOfPagerWrapper(); $test->run(new HtmlReporter()); } ?>
Close