Update bass streaming test to include opus as well
This commit is contained in:
parent
1fc6c85568
commit
ba47b5d35e
@ -4,4 +4,4 @@ find_package(Catch2 REQUIRED)
|
|||||||
add_executable(test test_aopacket.cpp test_caseloading.cpp test_apng.cpp test_bass.cpp ../include/aopacket.h ../src/aopacket.cpp)
|
add_executable(test test_aopacket.cpp test_caseloading.cpp test_apng.cpp test_bass.cpp ../include/aopacket.h ../src/aopacket.cpp)
|
||||||
target_include_directories(test PRIVATE ../include)
|
target_include_directories(test PRIVATE ../include)
|
||||||
target_link_directories(test PRIVATE ../lib)
|
target_link_directories(test PRIVATE ../lib)
|
||||||
target_link_libraries(test PRIVATE Qt5::Core Qt5::Gui Catch2::Catch2 bass)
|
target_link_libraries(test PRIVATE Qt5::Core Qt5::Gui Catch2::Catch2 bass bassopus)
|
||||||
|
@ -5,16 +5,26 @@
|
|||||||
#include <QString>
|
#include <QString>
|
||||||
|
|
||||||
#include "bass.h"
|
#include "bass.h"
|
||||||
|
#include "bassopus.h"
|
||||||
|
|
||||||
TEST_CASE("BASS URL streaming", "[bass]") {
|
TEST_CASE("BASS URL streaming", "[bass]") {
|
||||||
// Sample
|
// Sample
|
||||||
QString url = "https://raw.githubusercontent.com/skyedeving/aocharedit/master/Attorney%20Online%20Character%20Editor/Resources/about.mp3";
|
QString url = "https://raw.githubusercontent.com/skyedeving/aocharedit/master/Attorney%20Online%20Character%20Editor/Resources/about.mp3";
|
||||||
|
|
||||||
|
// initialize
|
||||||
BASS_Init(-1, 44100, 0, 0, nullptr);
|
BASS_Init(-1, 44100, 0, 0, nullptr);
|
||||||
#ifdef _WIN32
|
|
||||||
HSTREAM stream = BASS_StreamCreateURL(url.toWStdString().c_str(), 0, BASS_STREAM_STATUS, nullptr, 0);
|
// create stream from url
|
||||||
#else
|
HSTREAM stream;
|
||||||
HSTREAM stream = BASS_StreamCreateURL(url.toStdString().c_str(), 0, BASS_STREAM_STATUS, nullptr, 0);
|
unsigned int flags = BASS_STREAM_AUTOFREE | BASS_STREAM_STATUS;
|
||||||
#endif
|
if (url.endsWith(".opus")) {
|
||||||
|
stream = BASS_OPUS_StreamCreateURL(url.toStdString().c_str(), 0, flags, nullptr, 0);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
stream = BASS_StreamCreateURL(url.toStdString().c_str(), 0, flags, nullptr, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Log http status
|
||||||
const char *tags = BASS_ChannelGetTags(stream, BASS_TAG_HTTP);
|
const char *tags = BASS_ChannelGetTags(stream, BASS_TAG_HTTP);
|
||||||
if (tags) {
|
if (tags) {
|
||||||
while(*tags) {
|
while(*tags) {
|
||||||
@ -22,7 +32,9 @@ TEST_CASE("BASS URL streaming", "[bass]") {
|
|||||||
tags += strlen(tags) + 1;
|
tags += strlen(tags) + 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Test
|
||||||
REQUIRE(stream != 0);
|
REQUIRE(stream != 0);
|
||||||
REQUIRE(BASS_ChannelPlay(stream, TRUE) == TRUE);
|
REQUIRE(BASS_ChannelPlay(stream, TRUE) == TRUE);
|
||||||
// while (BASS_ChannelIsActive(stream) != BASS_ACTIVE_STOPPED);
|
// while (BASS_ChannelIsActive(stream) != BASS_ACTIVE_STOPPED); // block test to listen
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user