forked from vufind-org/vufind
-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add Mink test for fallback loader functionality.
- Loading branch information
1 parent
9c2b1f7
commit 29303b4
Showing
1 changed file
with
183 additions
and
0 deletions.
There are no files selected for viewing
183 changes: 183 additions & 0 deletions
183
module/VuFind/tests/integration-tests/src/VuFindTest/Mink/FallbackLoaderTest.php
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,183 @@ | ||
<?php | ||
|
||
/** | ||
* Mink fallback loader test class. | ||
* | ||
* PHP version 8 | ||
* | ||
* Copyright (C) Villanova University 2025. | ||
* | ||
* This program is free software; you can redistribute it and/or modify | ||
* it under the terms of the GNU General Public License version 2, | ||
* as published by the Free Software Foundation. | ||
* | ||
* This program is distributed in the hope that it will be useful, | ||
* but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
* GNU General Public License for more details. | ||
* | ||
* You should have received a copy of the GNU General Public License | ||
* along with this program; if not, write to the Free Software | ||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | ||
* | ||
* @category VuFind | ||
* @package Tests | ||
* @author Demian Katz <[email protected]> | ||
* @author Juha Luoma <[email protected]> | ||
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License | ||
* @link https://vufind.org Main Page | ||
*/ | ||
|
||
namespace VuFindTest\Mink; | ||
|
||
use Behat\Mink\Element\Element; | ||
use Exception; | ||
use PHPUnit\Framework\ExpectationFailedException; | ||
use VuFind\Db\Service\ResourceService; | ||
|
||
/** | ||
* Mink fallback loader test class. | ||
* | ||
* Class must be final due to use of "new static()" by LiveDatabaseTrait. | ||
* | ||
* @category VuFind | ||
* @package Tests | ||
* @author Demian Katz <[email protected]> | ||
* @author Juha Luoma <[email protected]> | ||
* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License | ||
* @link https://vufind.org Main Page | ||
*/ | ||
final class FallbackLoaderTest extends \VuFindTest\Integration\MinkTestCase | ||
{ | ||
use \VuFindTest\Feature\LiveDatabaseTrait; | ||
use \VuFindTest\Feature\UserCreationTrait; | ||
|
||
/** | ||
* Standard setup method. | ||
* | ||
* @return void | ||
*/ | ||
public static function setUpBeforeClass(): void | ||
{ | ||
static::failIfDataExists(); | ||
} | ||
|
||
/** | ||
* Go to the specified record page. | ||
* | ||
* @param string $id Record to visit | ||
* | ||
* @return Element | ||
*/ | ||
protected function goToRecord(string $id): Element | ||
{ | ||
$session = $this->getMinkSession(); | ||
$session->visit($this->getVuFindUrl() . '/Record/' . $id); | ||
return $session->getPage(); | ||
} | ||
|
||
/** | ||
* Add a comment (assumes you are on record page and logged in). | ||
* | ||
* @param Element $page Page object | ||
* @param string $comment Comment to add. | ||
* | ||
* @return void | ||
*/ | ||
protected function addComment(Element $page, string $comment): void | ||
{ | ||
$this->clickCss($page, '.record-tabs .usercomments a'); | ||
$this->findCss($page, '.comment-form'); | ||
$this->findCssAndSetValue($page, 'form.comment-form [name="comment"]', $comment); | ||
$this->clickCss($page, 'form.comment-form .btn-primary'); | ||
} | ||
|
||
/** | ||
* Assert that the expected merged tags and comments are present on the page. | ||
* | ||
* @param Element $page Page object | ||
* | ||
* @return void | ||
* @throws Exception | ||
* @throws ExpectationFailedException | ||
*/ | ||
protected function assertMergedResults(Element $page): void | ||
{ | ||
$this->assertEquals('new_tag 1 old_tag 1', $this->findCssAndGetText($page, '.tagList')); | ||
$this->clickCss($page, '.record-tabs .usercomments a'); | ||
$this->assertEquals('old comment', $this->findCssAndGetText($page, '.comment-text', index: 0)); | ||
$this->assertEquals('new comment', $this->findCssAndGetText($page, '.comment-text', index: 1)); | ||
} | ||
|
||
/** | ||
* Test the fallback loader, based on manuial procedure documented at this wiki page: | ||
* https://vufind.org/wiki/development:testing:manual_testing#merging_record_data_when_ids_change | ||
* | ||
* @return void | ||
*/ | ||
public function testFallbackLoader(): void | ||
{ | ||
$newId = 'vtls000000329'; | ||
$oldId = '(IeDuNL)1048'; | ||
|
||
// Create a user account and create a favorite, tag and comment to serve as "old data": | ||
$page = $this->gotoRecord($newId); | ||
$this->clickCss($page, '.save-record'); | ||
$this->clickCss($page, '.modal-body .createAccountLink'); | ||
$this->fillInAccountForm($page); | ||
$this->clickCss($page, '.modal-body .btn.btn-primary'); | ||
$this->findCss($page, '#save_list'); | ||
$this->findCssAndSetValue($page, '#add_mytags', 'old_tag'); | ||
$this->clickCss($page, '.modal-body .btn.btn-primary'); | ||
$this->findCss($page, '.modal .alert.alert-success'); | ||
$this->clickCss($page, '.modal-body .btn.btn-default'); | ||
$this->waitForLightboxHidden(); | ||
$this->addComment($page, 'old comment'); | ||
|
||
// We created the "old data" on the new ID, because the old ID doesn't really exist; our test | ||
// is just a simulation. Thus, we need to migrate the newly-created data to the old ID manually: | ||
$resourceService = $this->getDbService(ResourceService::class); | ||
$resource = $resourceService->getResourceByRecordId($newId); | ||
$resource->setRecordId($oldId); | ||
$resourceService->persistEntity($resource); | ||
|
||
// Now that the data has been moved away, let's create a new set of data on the new ID: | ||
$this->clickCss($page, '.save-record'); | ||
$this->findCss($page, '#save_list'); | ||
$this->findCssAndSetValue($page, '#add_mytags', 'new_tag'); | ||
$this->clickCss($page, '.modal-body .btn.btn-primary'); | ||
$this->findCss($page, '.modal .alert.alert-success'); | ||
$this->clickCss($page, '.modal-body .btn.btn-default'); | ||
$this->waitForLightboxHidden(); | ||
$this->addComment($page, 'new comment'); | ||
|
||
// Now set up the Solr-based fallback loader to use the ctrlnum field as the fallback ID. This is | ||
// how we trick the test environment into thinking that $oldId is a previous identifier for $newId, | ||
// based on data in our existing test records. | ||
$this->changeConfigs( | ||
[ | ||
'searches' => [ | ||
'General' => [ | ||
'fallback_id_field' => 'ctrlnum', | ||
], | ||
], | ||
] | ||
); | ||
|
||
// Now, try to access the old ID -- it should contain all of our data merged together: | ||
$this->assertMergedResults($this->goToRecord($oldId)); | ||
|
||
// Finally, return to the new ID -- it should also contain the same information: | ||
$this->assertMergedResults($this->goToRecord($newId)); | ||
} | ||
|
||
/** | ||
* Standard teardown method. | ||
* | ||
* @return void | ||
*/ | ||
public static function tearDownAfterClass(): void | ||
{ | ||
static::removeUsers(['username1']); | ||
} | ||
} |