Tracking: Cover markers access with basic tests

Just a beginning of tests coverage, related on the planned upcoming
development.
This commit is contained in:
Sergey Sharybin 2020-11-20 17:11:00 +01:00
parent 1e0ff6b723
commit 401612b8e1
2 changed files with 65 additions and 0 deletions

View File

@ -720,6 +720,7 @@ if(WITH_GTESTS)
intern/armature_test.cc
intern/fcurve_test.cc
intern/lattice_deform_test.cc
intern/tracking_test.cc
)
set(TEST_INC
../editors/include

View File

@ -0,0 +1,64 @@
/* Apache License, Version 2.0 */
#include "testing/testing.h"
#include "DNA_tracking_types.h"
#include "BKE_tracking.h"
namespace {
class TrackingTest : public ::testing::Test {
protected:
MovieTrackingMarker *addMarkerToTrack(MovieTrackingTrack *track, int frame_number)
{
MovieTrackingMarker marker = {{0.0f}};
marker.framenr = frame_number;
return BKE_tracking_marker_insert(track, &marker);
}
};
} // namespace
TEST_F(TrackingTest, BKE_tracking_marker_get)
{
MovieTrackingTrack track = {nullptr};
addMarkerToTrack(&track, 1);
addMarkerToTrack(&track, 10);
{
const MovieTrackingMarker *marker = BKE_tracking_marker_get(&track, 1);
EXPECT_NE(marker, nullptr);
EXPECT_EQ(marker->framenr, 1);
}
{
const MovieTrackingMarker *marker = BKE_tracking_marker_get(&track, 5);
EXPECT_NE(marker, nullptr);
EXPECT_EQ(marker->framenr, 1);
}
BKE_tracking_track_free(&track);
}
TEST_F(TrackingTest, BKE_tracking_marker_get_exact)
{
MovieTrackingTrack track = {nullptr};
addMarkerToTrack(&track, 1);
addMarkerToTrack(&track, 10);
{
const MovieTrackingMarker *marker = BKE_tracking_marker_get_exact(&track, 1);
EXPECT_NE(marker, nullptr);
EXPECT_EQ(marker->framenr, 1);
}
{
const MovieTrackingMarker *marker = BKE_tracking_marker_get_exact(&track, 5);
EXPECT_EQ(marker, nullptr);
}
BKE_tracking_track_free(&track);
}