1
0
mirror of https://github.com/clementine-player/Clementine synced 2024-12-14 18:35:16 +01:00
Clementine-audio-player-Mac.../tests/database_test.cpp
David Sansome 1b00aaa8b3 Big refactoring of the Library <-> LibraryBackend <-> SQLite interaction.
The LibraryBackend has now been split into a Database class that deals with setting up sqlite, and PlaylistBackend that contains the functions for persisting the playlist.  The LibraryBackend now only contains functions for accessing "a collection of songs", and can be parameterised with table names to access different collections.  It also no longer lives in a background thread, and follows the Qt memory management model instead of using shared_ptr.
Most of Library has been moved into LibraryModel - a QAbstractItemModel for any LibraryBackend.  What's left of Library is now specific to the user's local library on disk.
2010-05-09 00:10:26 +00:00

127 lines
3.5 KiB
C++

/* This file is part of Clementine.
Clementine 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.
Clementine 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 Clementine. If not, see <http://www.gnu.org/licenses/>.
*/
#include "test_utils.h"
#include "gtest/gtest.h"
#include "database.h"
#include <boost/scoped_ptr.hpp>
#include <QtDebug>
#include <QSqlQuery>
#include <QVariant>
class DatabaseTest : public ::testing::Test {
protected:
virtual void SetUp() {
database_.reset(new MemoryDatabase);
}
boost::scoped_ptr<Database> database_;
};
#ifdef Q_OS_UNIX
#include <sys/time.h>
#include <time.h>
struct PerfTimer {
PerfTimer(int iterations) : iterations_(iterations) {
gettimeofday(&start_time_, NULL);
}
~PerfTimer() {
gettimeofday(&end_time_, NULL);
timeval elapsed_time;
timersub(&end_time_, &start_time_, &elapsed_time);
int elapsed_us = elapsed_time.tv_usec + elapsed_time.tv_sec * 1000000;
qDebug() << "Elapsed:" << elapsed_us << "us";
qDebug() << "Time per iteration:" << float(elapsed_us) / iterations_ << "us";
}
timeval start_time_;
timeval end_time_;
int iterations_;
};
TEST_F(DatabaseTest, LikePerformance) {
const int iterations = 1000000;
const char* needle = "foo";
const char* haystack = "foobarbaz foobarbaz";
qDebug() << "Simple query";
{
PerfTimer perf(iterations);
for (int i = 0; i < iterations; ++i) {
database_->Like(needle, haystack);
}
}
}
#endif
TEST_F(DatabaseTest, DatabaseInitialises) {
// Check that these tables exist
QStringList tables = database_->Connect().tables();
EXPECT_TRUE(tables.contains("songs"));
EXPECT_TRUE(tables.contains("directories"));
EXPECT_TRUE(tables.contains("subdirectories"));
EXPECT_TRUE(tables.contains("playlists"));
EXPECT_TRUE(tables.contains("playlist_items"));
ASSERT_TRUE(tables.contains("schema_version"));
// Check the schema version is correct
QSqlQuery q("SELECT version FROM schema_version", database_->Connect());
ASSERT_TRUE(q.exec());
ASSERT_TRUE(q.next());
EXPECT_EQ(Database::kSchemaVersion, q.value(0).toInt());
EXPECT_FALSE(q.next());
}
TEST_F(DatabaseTest, LikeWorksWithAllAscii) {
EXPECT_TRUE(database_->Like("%ar%", "bar"));
EXPECT_FALSE(database_->Like("%ar%", "foo"));
}
TEST_F(DatabaseTest, LikeWorksWithUnicode) {
EXPECT_TRUE(database_->Like("%Снег%", "Снег"));
EXPECT_FALSE(database_->Like("%Снег%", "foo"));
}
TEST_F(DatabaseTest, LikeAsciiCaseInsensitive) {
EXPECT_TRUE(database_->Like("%ar%", "BAR"));
EXPECT_FALSE(database_->Like("%ar%", "FOO"));
}
TEST_F(DatabaseTest, LikeUnicodeCaseInsensitive) {
EXPECT_TRUE(database_->Like("%снег%", "Снег"));
}
TEST_F(DatabaseTest, LikeCacheInvalidated) {
EXPECT_TRUE(database_->Like("%foo%", "foobar"));
EXPECT_FALSE(database_->Like("%baz%", "foobar"));
}
TEST_F(DatabaseTest, LikeQuerySplit) {
EXPECT_TRUE(database_->Like("%foo bar%", "foobar"));
EXPECT_FALSE(database_->Like("%foo bar%", "barbaz"));
EXPECT_FALSE(database_->Like("%foo bar%", "foobaz"));
EXPECT_FALSE(database_->Like("%foo bar%", "baz"));
}