summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2022-06-03 20:07:57 +0200
committerCarl Hetherington <cth@carlh.net>2022-06-03 22:40:59 +0200
commit6fa6f0a7ca116c6cf5dc5b8d2e8ed3a0fd4a6127 (patch)
tree04c01959d9849967460a9c2e780009c2986299f3 /test
parent12f089b89fff8409cd012cab1ba4eb8b619e554e (diff)
Make subtitle asset filename obey custom settings (#2260).
Diffstat (limited to 'test')
-rw-r--r--test/file_naming_test.cc40
1 files changed, 36 insertions, 4 deletions
diff --git a/test/file_naming_test.cc b/test/file_naming_test.cc
index 0b76952a8..4f6d66fe6 100644
--- a/test/file_naming_test.cc
+++ b/test/file_naming_test.cc
@@ -27,9 +27,10 @@
#include "test.h"
#include "lib/config.h"
-#include "lib/film.h"
-#include "lib/ffmpeg_content.h"
+#include "lib/content_factory.h"
#include "lib/dcp_content_type.h"
+#include "lib/ffmpeg_content.h"
+#include "lib/film.h"
#include "lib/video_content.h"
#ifdef DCPOMATIC_WINDOWS
#include <boost/locale.hpp>
@@ -38,9 +39,9 @@
#include <boost/regex.hpp>
-using std::string;
-using std::shared_ptr;
using std::make_shared;
+using std::shared_ptr;
+using std::string;
class Keep
@@ -170,3 +171,34 @@ BOOST_AUTO_TEST_CASE (file_naming_test2)
BOOST_CHECK (got[i] == 2);
}
}
+
+
+BOOST_AUTO_TEST_CASE (subtitle_file_naming)
+{
+ Keep keep;
+
+ Config::instance()->set_dcp_asset_filename_format(dcp::NameFormat("%t ostrabagalous %c"));
+
+ auto content = content_factory("test/data/15s.srt");
+ auto film = new_test_film2("subtitle_file_naming", { content.front() });
+ film->set_interop(false);
+
+ make_and_verify_dcp (
+ film,
+ {
+ dcp::VerificationNote::Code::MISSING_CPL_METADATA,
+ dcp::VerificationNote::Code::MISSING_SUBTITLE_LANGUAGE,
+ dcp::VerificationNote::Code::INVALID_SUBTITLE_FIRST_TEXT_TIME,
+ });
+
+ int got = 0;
+
+ for (auto i: boost::filesystem::directory_iterator(film->file(film->dcp_name()))) {
+ if (boost::regex_match(i.path().filename().string(), boost::regex("sub_ostrabagalous_15s.*\\.mxf"))) {
+ ++got;
+ }
+ }
+
+ BOOST_CHECK_EQUAL(got, 1);
+}
+