1
0
mirror of https://github.com/clementine-player/Clementine synced 2025-01-07 07:41:54 +01:00
Clementine-audio-player-Mac.../tests/m3uparser_test.cpp

170 lines
5.6 KiB
C++

/* This file is part of Clementine.
Copyright 2010, David Sansome <me@davidsansome.com>
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 "gmock/gmock-matchers.h"
#include "gtest/gtest.h"
#include "test_utils.h"
#include "mock_taglib.h"
#include "playlistparsers/m3uparser.h"
#include <QBuffer>
#include <QTemporaryFile>
using ::testing::HasSubstr;
class M3UParserTest : public ::testing::Test {
protected:
static void SetUpTestCase() {
testing::DefaultValue<TagLib::String>::Set("foobarbaz");
}
M3UParserTest()
: parser_(NULL) {
}
M3UParser parser_;
MockFileRefFactory taglib_;
};
TEST_F(M3UParserTest, ParsesMetadata) {
QString line("#EXTINF:123,Foo artist - Foo track");
M3UParser::Metadata metadata;
ASSERT_TRUE(parser_.ParseMetadata(line, &metadata));
EXPECT_EQ("Foo artist", metadata.artist.toStdString());
EXPECT_EQ("Foo track", metadata.title.toStdString());
EXPECT_EQ(123 * kNsecPerSec, metadata.length);
}
TEST_F(M3UParserTest, ParsesTrackLocation) {
QTemporaryFile temp;
temp.open();
taglib_.ExpectCall(temp.fileName(), "foo", "bar", "baz");
Song song(&taglib_);
QString line(temp.fileName());
parser_.LoadSong(line, 0, QDir(), &song);
ASSERT_EQ(QUrl::fromLocalFile(temp.fileName()), song.url());
song.InitFromFile(song.url().toLocalFile(), -1);
EXPECT_EQ("foo", song.title());
EXPECT_EQ("bar", song.artist());
EXPECT_EQ("baz", song.album());
}
TEST_F(M3UParserTest, ParsesTrackLocationRelative) {
QTemporaryFile temp;
temp.open();
QFileInfo info(temp);
taglib_.ExpectCall(temp.fileName(), "foo", "bar", "baz");
M3UParser parser(NULL);
QString line(info.fileName());
Song song(&taglib_);
parser.LoadSong(line, 0, info.dir(), &song);
ASSERT_EQ(QUrl::fromLocalFile(temp.fileName()), song.url());
song.InitFromFile(song.url().toLocalFile(), -1);
EXPECT_EQ("foo", song.title());
}
TEST_F(M3UParserTest, ParsesTrackLocationHttp) {
QString line("http://example.com/foo/bar.mp3");
Song song;
parser_.LoadSong(line, 0, QDir(), &song);
EXPECT_EQ(QUrl("http://example.com/foo/bar.mp3"), song.url());
}
TEST_F(M3UParserTest, ParsesSongsFromDevice) {
QByteArray data = "#EXTM3U\n"
"#EXTINF:123,Some Artist - Some Title\n"
"http://foo.com/bar/somefile.mp3\n";
QBuffer buffer(&data);
buffer.open(QIODevice::ReadOnly);
M3UParser parser(NULL);
SongList songs = parser.Load(&buffer);
ASSERT_EQ(1, songs.size());
Song s = songs[0];
EXPECT_EQ("Some Artist", s.artist());
EXPECT_EQ("Some Title", s.title());
EXPECT_EQ(123 * kNsecPerSec, s.length_nanosec());
EXPECT_EQ(QUrl("http://foo.com/bar/somefile.mp3"), s.url());
}
TEST_F(M3UParserTest, ParsesNonExtendedM3U) {
QByteArray data = "http://foo.com/bar/somefile.mp3\n"
"http://baz.com/thing.mp3\n";
QBuffer buffer(&data);
buffer.open(QIODevice::ReadOnly);
M3UParser parser(NULL);
SongList songs = parser.Load(&buffer, "", QDir("somedir"));
ASSERT_EQ(2, songs.size());
EXPECT_EQ(QUrl("http://foo.com/bar/somefile.mp3"), songs[0].url());
EXPECT_EQ(QUrl("http://baz.com/thing.mp3"), songs[1].url());
EXPECT_EQ(-1, songs[0].length_nanosec());
EXPECT_EQ(-1, songs[1].length_nanosec());
EXPECT_TRUE(songs[0].artist().isEmpty());
}
TEST_F(M3UParserTest, ParsesActualM3U) {
QFile file(":testdata/test.m3u");
file.open(QIODevice::ReadOnly);
M3UParser parser(NULL);
SongList songs = parser.Load(&file, "", QDir("somedir"));
ASSERT_EQ(239, songs.size());
EXPECT_EQ("gravity", songs[0].title());
EXPECT_EQ(203 * kNsecPerSec, songs[0].length_nanosec());
EXPECT_EQ(QString::fromUtf8("ほっぴンちょっぴン"), songs.back().title());
EXPECT_EQ(85 * kNsecPerSec, songs.back().length_nanosec());
}
TEST_F(M3UParserTest, SavesSong) {
QByteArray data;
QBuffer buffer(&data);
buffer.open(QIODevice::WriteOnly);
Song one;
one.set_filetype(Song::Type_Stream);
one.set_title("foo");
one.set_artist("bar");
one.set_length_nanosec(123 * kNsecPerSec);
one.set_url(QUrl("http://www.example.com/foo.mp3"));
SongList songs;
songs << one;
M3UParser parser(NULL);
parser.Save(songs, &buffer);
EXPECT_THAT(data.constData(), HasSubstr("#EXTM3U"));
EXPECT_THAT(data.constData(), HasSubstr("#EXTINF:123,bar - foo"));
EXPECT_THAT(data.constData(), HasSubstr("http://www.example.com/foo.mp3"));
}
TEST_F(M3UParserTest, ParsesUTF8) {
QByteArray data = "#EXTM3U\n"
"#EXTINF:123,Разные - исполнители\n"
"/foo/Разные/исполнители.mp3\n";
QBuffer buffer(&data);
buffer.open(QIODevice::ReadOnly);
M3UParser parser(NULL);
SongList songs = parser.Load(&buffer);
ASSERT_EQ(1, songs.length());
EXPECT_EQ(6, songs[0].artist().length());
EXPECT_EQ(11, songs[0].title().length());
EXPECT_EQ(QString::fromUtf8("Разные"), songs[0].artist());
EXPECT_EQ(QString::fromUtf8("исполнители"), songs[0].title());
EXPECT_EQ(QUrl::fromLocalFile(QString::fromUtf8("/foo/Разные/исполнители.mp3")),
songs[0].url());
}