Bug 34336: Remove the dependency for Test::DBIx::Class
The module is removed from t. We only have 01-test_dbic.t and we do not need it any longer. Test plan: git grep for Test::DBIx::Class. You should only see release notes. Signed-off-by: Marcel de Rooy <m.de.rooy@rijksmuseum.nl> Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org> Signed-off-by: Tomas Cohen Arazi <tomascohen@theke.io>
This commit is contained in:
parent
c92f23901e
commit
d163bf0b86
2 changed files with 0 additions and 111 deletions
1
cpanfile
1
cpanfile
|
@ -166,7 +166,6 @@ recommends 'Selenium::Remote::Driver', '1.27';
|
|||
recommends 'Starman', '0.4014';
|
||||
recommends 'Sys::CPU', '0.52';
|
||||
recommends 'Template::Plugin::Stash', '1.006';
|
||||
recommends 'Test::DBIx::Class', '0.42';
|
||||
recommends 'Test::Deep', '0.106';
|
||||
recommends 'Test::Exception', '0.35';
|
||||
recommends 'Test::MockObject', '1.09';
|
||||
|
|
|
@ -1,110 +0,0 @@
|
|||
#!/usr/bin/perl
|
||||
|
||||
# This file is part of Koha.
|
||||
#
|
||||
# Koha is free software; you can redistribute it and/or modify it under the
|
||||
# terms of the GNU General Public License as published by the Free Software
|
||||
# Foundation; either version 3 of the License, or (at your option) any later
|
||||
# version.
|
||||
#
|
||||
# Koha 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 Koha; if not, see <http://www.gnu.org/licenses>.
|
||||
|
||||
use Modern::Perl;
|
||||
|
||||
use Test::More;
|
||||
use Test::MockModule;
|
||||
|
||||
use Koha::Database;
|
||||
use Koha::Libraries;
|
||||
|
||||
subtest "Scenario: Show how caching prevents Test::DBIx::Class from working properly and how to circumvent it", sub {
|
||||
my ( $firstSchema, $cachedSchema, $cachedSchema2, $firstLibCount, $libCount );
|
||||
|
||||
eval {
|
||||
|
||||
ok(
|
||||
$firstSchema = Koha::Database->schema,
|
||||
'Step: Given a normal DB connection.'
|
||||
);
|
||||
|
||||
$firstLibCount =
|
||||
Koha::Libraries->search->count; # first count normal conn
|
||||
|
||||
ok( $cachedSchema = Koha::Database::get_schema_cached(),
|
||||
' And the DB connection is cached' );
|
||||
|
||||
unlike( getConnectionDBName($cachedSchema),
|
||||
qr/sqlite/i, ' And the cached DB connection type is not sqlite' );
|
||||
|
||||
use_ok('Test::DBIx::Class');
|
||||
my $db = Test::MockModule->new('Koha::Database');
|
||||
$db->mock( _new_schema => sub { return Schema(); } );
|
||||
ok( 1,
|
||||
'Step: Given Test::DBIx::Class (T:D:C) is loaded and DB accessor is mocked. Connection from cache is still used.'
|
||||
);
|
||||
|
||||
$libCount = Koha::Libraries->search->count;
|
||||
|
||||
is( $libCount, $firstLibCount,
|
||||
' Then we got the same count as without T:D:C' );
|
||||
|
||||
$cachedSchema = Koha::Database::get_schema_cached();
|
||||
is( $cachedSchema, $firstSchema,
|
||||
' And the cached DB connection is the same as without T:D:C' );
|
||||
|
||||
is(
|
||||
getConnectionDBName($cachedSchema),
|
||||
getConnectionDBName($firstSchema),
|
||||
' And the cached DB connection type is unchanged'
|
||||
);
|
||||
|
||||
ok( Koha::Database::flush_schema_cache(),
|
||||
'Step: Given the DB connection cache is flushed' );
|
||||
|
||||
$libCount = Koha::Libraries->search->count;
|
||||
|
||||
is( $libCount, 0,
|
||||
' Then we got 0 libraries because fixtures are not deployed' );
|
||||
|
||||
$cachedSchema = Koha::Database::get_schema_cached();
|
||||
isnt( $cachedSchema, $firstSchema,
|
||||
' And the cached DB connection has changed' );
|
||||
|
||||
like( getConnectionDBName($cachedSchema),
|
||||
qr/sqlite/i, ' And the cached DB connection type is sqlite' );
|
||||
|
||||
fixtures_ok(
|
||||
[ #Dynamically load fixtures, because we dynamically load T:D:C. Otherwise there be compile errors!
|
||||
Branch => [
|
||||
[ 'branchcode', 'branchname' ],
|
||||
[ 'XXX_test', 'my branchname XXX' ],
|
||||
]
|
||||
],
|
||||
'Step: Given we deploy T:D:C Fixtures'
|
||||
);
|
||||
|
||||
$libCount = Koha::Libraries->search->count;
|
||||
|
||||
is( $libCount, 1, ' Then we got the count from fixtures' );
|
||||
|
||||
$cachedSchema2 = Koha::Database::get_schema_cached();
|
||||
is( $cachedSchema2, $cachedSchema,
|
||||
' And the cached DB connection is the same from T:D:C' );
|
||||
|
||||
like( getConnectionDBName($cachedSchema),
|
||||
qr/sqlite/i, ' And the cached DB connection type is sqlite' );
|
||||
|
||||
};
|
||||
ok( 0, $@ ) if $@;
|
||||
};
|
||||
|
||||
done_testing;
|
||||
|
||||
sub getConnectionDBName {
|
||||
return shift->storage->connect_info->[0]->{dsn};
|
||||
}
|
Loading…
Reference in a new issue