mirror of
https://gitlab.com/mbunkus/mkvtoolnix.git
synced 2025-01-04 09:15:05 +00:00
b1c4f7f47f
Part of an ongoing effort to replace the use of the term 'timecode' with 'timestamp'. Timecodes have a very specific meaning in the audio/video world, and it's not what MKVToolNix has been using the term for.
71 lines
3.2 KiB
C++
71 lines
3.2 KiB
C++
#include "common/common_pch.h"
|
|
|
|
#include "common/strings/formatting.h"
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
namespace {
|
|
|
|
TEST(StringsFormatting, FileSize) {
|
|
EXPECT_EQ("1023 bytes", format_file_size( 1023ll));
|
|
EXPECT_EQ( "1.0 KiB", format_file_size( 1024ll));
|
|
EXPECT_EQ( "1.9 KiB", format_file_size( 2047ll));
|
|
EXPECT_EQ( "2.0 KiB", format_file_size( 2048ll));
|
|
EXPECT_EQ("1023.9 KiB", format_file_size( 1048575ll));
|
|
EXPECT_EQ( "1.0 MiB", format_file_size( 1048576ll));
|
|
EXPECT_EQ( "1.9 MiB", format_file_size( 2097151ll));
|
|
EXPECT_EQ( "2.0 MiB", format_file_size( 2097152ll));
|
|
EXPECT_EQ("1023.9 MiB", format_file_size(1073741823ll));
|
|
EXPECT_EQ( "1.0 GiB", format_file_size(1073741824ll));
|
|
EXPECT_EQ( "1.9 GiB", format_file_size(2147483647ll));
|
|
EXPECT_EQ( "2.0 GiB", format_file_size(2147483648ll));
|
|
}
|
|
|
|
TEST(StringsFormatting, FormatTimecodeWithPrecision) {
|
|
auto value = 567891234ll + 1000000000ll * (34 + 2 * 60 + 1 * 3600);
|
|
|
|
EXPECT_EQ("01:02:34.567891234", format_timestamp(value));
|
|
EXPECT_EQ("01:02:34.567891234", format_timestamp(value, 10));
|
|
EXPECT_EQ("01:02:34.567891234", format_timestamp(value, 9));
|
|
EXPECT_EQ("01:02:34.56789123", format_timestamp(value, 8));
|
|
EXPECT_EQ("01:02:34.5678912", format_timestamp(value, 7));
|
|
EXPECT_EQ("01:02:34.567891", format_timestamp(value, 6));
|
|
EXPECT_EQ("01:02:34.56789", format_timestamp(value, 5));
|
|
EXPECT_EQ("01:02:34.5679", format_timestamp(value, 4));
|
|
EXPECT_EQ("01:02:34.568", format_timestamp(value, 3));
|
|
EXPECT_EQ("01:02:34.57", format_timestamp(value, 2));
|
|
EXPECT_EQ("01:02:34.6", format_timestamp(value, 1));
|
|
EXPECT_EQ("01:02:35", format_timestamp(value, 0));
|
|
}
|
|
|
|
TEST(StringsFormatting, FormatTimecodeWithFormat) {
|
|
auto value = 567890000ll + 1000000000ll * (34 + 2 * 60 + 1 * 3600);
|
|
|
|
EXPECT_EQ("1", format_timestamp(value, "%h"));
|
|
EXPECT_EQ("01", format_timestamp(value, "%H"));
|
|
EXPECT_EQ("2", format_timestamp(value, "%m"));
|
|
EXPECT_EQ("02", format_timestamp(value, "%M"));
|
|
EXPECT_EQ("34", format_timestamp(value, "%s"));
|
|
EXPECT_EQ("34", format_timestamp(value, "%S"));
|
|
EXPECT_EQ("567890000", format_timestamp(value, "%n"));
|
|
|
|
EXPECT_EQ("567890000", format_timestamp(value, "%9n"));
|
|
EXPECT_EQ("56789000", format_timestamp(value, "%8n"));
|
|
EXPECT_EQ("5678900", format_timestamp(value, "%7n"));
|
|
EXPECT_EQ("567890", format_timestamp(value, "%6n"));
|
|
EXPECT_EQ("56789", format_timestamp(value, "%5n"));
|
|
EXPECT_EQ("5678", format_timestamp(value, "%4n"));
|
|
EXPECT_EQ("567", format_timestamp(value, "%3n"));
|
|
EXPECT_EQ("56", format_timestamp(value, "%2n"));
|
|
EXPECT_EQ("5", format_timestamp(value, "%1n"));
|
|
EXPECT_EQ("567890000", format_timestamp(value, "%0n"));
|
|
|
|
EXPECT_EQ("%", format_timestamp(value, "%%"));
|
|
EXPECT_EQ("z", format_timestamp(value, "z"));
|
|
EXPECT_EQ("q", format_timestamp(value, "%q"));
|
|
|
|
EXPECT_EQ("01:02:34.567890000", format_timestamp(value, "%H:%M:%S.%n"));
|
|
}
|
|
|
|
}
|