Skip to content

Commit

Permalink
Use @dataProvider in testPseudoClassNthChild() to reduce code repetition
Browse files Browse the repository at this point in the history
  • Loading branch information
super-dm3 committed Nov 6, 2024
1 parent 1f10bfa commit 4e2895f
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 95 deletions.
1 change: 1 addition & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ QueryPath Changelog
# 4.0.2

- Fix for :nth-child(n+B) to select B-th and all following elements
- Update PHPUnit Test Suite to use @dataProvider in testPseudoClassNthChild() to reduce code repetition

# 4.0.1

Expand Down
128 changes: 33 additions & 95 deletions tests/QueryPath/CSS/QueryPathEventHandlerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -615,7 +615,31 @@ public function testChildAtIndex() {
$this->assertEquals('one', $this->nthMatch($matches, 1)->getAttribute('id'));
}*/

public function testPseudoClassNthChild()
public function nthChildProvider(): array
{
return [
[':root :even', 3, 'four' ], // full list
['i:even', 2, 'four' ], // restricted to specific element
['i:odd', 3, 'three' ], // restricted to specific element, odd this time
['i:nth-child(odd)', 3, 'three' ], // odd
['i:nth-child(2n+1)', 3, 'three' ], // odd, equiv to 2n + 1
['i:nth-child(2n-1)', 3, 'three' ], // odd, equiv to 2n + 1
['i:nth-child(2n)', 2, 'four' ], // even
//['i:nth-child(-2n)', 2, 'four' ], // Not totally sure what should be returned here
['i:nth-child(4n)', 1, 'four', 0], // every fourth row
['i:nth-child(4n+1)', 2, 'five' ], // first of every four rows
['i:nth-child(1)', 1, 'one', 0 ], // first row
['i:nth-child(0n-0)', 0, null ], // empty list
['i:nth-child(n+3)', 3, 'four' ], // third+ lines
//['i:nth-child(0n+3)', 1, 'three' ], // third element in a group of siblings
//['i:nth-child(-n+3)', 3, 'three' ], // first three lines
];
}

/**
* @dataProvider nthChildProvider
*/
public function testPseudoClassNthChild($selector, $matchesCount, $matchId, $matchIndex = 1)
{
$xml = '<?xml version="1.0" ?>
<test>
Expand All @@ -631,102 +655,16 @@ public function testPseudoClassNthChild()

// Test full list
$handler = new QueryPathEventHandler($doc);
$handler->find(':root :even');
$matches = $handler->getMatches();
$this->assertEquals(3, $matches->count());
$this->assertEquals('four', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test restricted to specific element
$handler = new QueryPathEventHandler($doc);
$handler->find('i:even');
$matches = $handler->getMatches();
$this->assertEquals(2, $matches->count());
$this->assertEquals('four', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test restricted to specific element, odd this time
$handler = new QueryPathEventHandler($doc);
$handler->find('i:odd');
$matches = $handler->getMatches();
$this->assertEquals(3, $matches->count());
$this->assertEquals('three', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test nth-child(odd)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(odd)');
$matches = $handler->getMatches();
$this->assertEquals(3, $matches->count());
$this->assertEquals('three', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test nth-child(2n+1)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(2n+1)');
$matches = $handler->getMatches();
$this->assertEquals(3, $matches->count());
$this->assertEquals('three', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test nth-child(2n) (even)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(2n)');
$matches = $handler->getMatches();
$this->assertEquals(2, $matches->count());
$this->assertEquals('four', $this->nthMatch($matches, 1)->getAttribute('id'));

// Not totally sure what should be returned here
// Test nth-child(-2n)
// $handler = new QueryPathEventHandler($doc);
// $handler->find('i:nth-child(-2n)');
// $matches = $handler->getMatches();
// $this->assertEquals(2, $matches->count());
// $this->assertEquals('four', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test nth-child(2n-1) (odd, equiv to 2n + 1)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(2n-1)');
$matches = $handler->getMatches();
$this->assertEquals(3, $matches->count());
$this->assertEquals('three', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test nth-child(4n) (every fourth row)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(4n)');
$handler->find($selector);
$matches = $handler->getMatches();
$this->assertEquals(1, $matches->count());
$this->assertEquals('four', $this->nthMatch($matches, 0)->getAttribute('id'));

// Test nth-child(4n+1) (first of every four rows)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(4n+1)');
$matches = $handler->getMatches();
// Should match rows one and five
$this->assertEquals(2, $matches->count());
$this->assertEquals('five', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test nth-child(1) (First row)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(1)');
$matches = $handler->getMatches();
$this->assertEquals(1, $matches->count());
$this->assertEquals('one', $this->firstMatch($matches)->getAttribute('id'));

// Test nth-child(0n-0) (Empty list)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(0n-0)');
$matches = $handler->getMatches();
$this->assertEquals(0, $matches->count());

// Test nth-child(n+3) (3+ elements)
$handler = new QueryPathEventHandler($doc);
$handler->find('i:nth-child(n+3)');
$matches = $handler->getMatches();
$this->assertEquals(3, $matches->count());
$this->assertEquals('four', $this->nthMatch($matches, 1)->getAttribute('id'));

// Test nth-child(-n+3) (First three lines)
// $handler = new QueryPathEventHandler($doc);
// $handler->find('i:nth-child(-n+3)');
// $matches = $handler->getMatches();
// $this->assertEquals(3, $matches->count());
$this->assertEquals($matchesCount, $matches->count());
if ($matchesCount) {
$this->assertEquals($matchId, $this->nthMatch($matches, $matchIndex)->getAttribute('id'));
}
}

public function testPseudoClassNthChildNested()
{
$xml = '<?xml version="1.0" ?>
<test>
<i class="odd" id="one"/>
Expand Down

0 comments on commit 4e2895f

Please sign in to comment.