blob: cc550248a32d19f5a4a28a00a08e2b2a3cc596fe [file] [log] [blame]
// Copyright 2014 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "services/view_manager/scheduled_animation_group.h"
#include "mojo/converters/geometry/geometry_type_converters.h"
#include "mojo/services/view_manager/interfaces/animations.mojom.h"
#include "services/view_manager/server_view.h"
#include "services/view_manager/test_server_view_delegate.h"
#include "testing/gtest/include/gtest/gtest.h"
using mojo::AnimationProperty;
using mojo::AnimationTweenType;
using mojo::AnimationGroup;
using mojo::AnimationSequence;
using mojo::AnimationElement;
using mojo::AnimationValue;
namespace view_manager {
namespace {
bool IsAnimationGroupValid(const AnimationGroup& transport_group) {
TestServerViewDelegate view_delegate;
ServerView view(&view_delegate, ViewId());
scoped_ptr<ScheduledAnimationGroup> group(ScheduledAnimationGroup::Create(
&view, base::TimeTicks::Now(), 1, transport_group));
return group.get() != nullptr;
}
} // namespace
TEST(ScheduledAnimationGroupTest, IsAnimationGroupValid) {
AnimationGroup group;
// AnimationGroup with no sequences is not valid.
EXPECT_FALSE(IsAnimationGroupValid(group));
group.sequences.push_back(AnimationSequence::New());
// Sequence with no elements is not valid.
EXPECT_FALSE(IsAnimationGroupValid(group));
AnimationSequence& sequence = *(group.sequences[0]);
sequence.elements.push_back(AnimationElement::New());
AnimationElement& element = *(sequence.elements[0]);
element.property = AnimationProperty::OPACITY;
element.tween_type = AnimationTweenType::LINEAR;
// Element with no target_value is not valid.
EXPECT_FALSE(IsAnimationGroupValid(group));
// Opacity must be between 0 and 1.
element.target_value = AnimationValue::New();
element.target_value->float_value = 2.5f;
EXPECT_FALSE(IsAnimationGroupValid(group));
element.target_value->float_value = .5f;
EXPECT_TRUE(IsAnimationGroupValid(group));
// Bogus start value.
element.start_value = AnimationValue::New();
element.start_value->float_value = 2.5f;
EXPECT_FALSE(IsAnimationGroupValid(group));
element.start_value->float_value = .5f;
EXPECT_TRUE(IsAnimationGroupValid(group));
// Bogus transform.
element.property = AnimationProperty::TRANSFORM;
EXPECT_FALSE(IsAnimationGroupValid(group));
element.start_value->transform = mojo::Transform::From(gfx::Transform());
EXPECT_FALSE(IsAnimationGroupValid(group));
element.target_value->transform = mojo::Transform::From(gfx::Transform());
EXPECT_TRUE(IsAnimationGroupValid(group));
// Add another empty sequence, should be invalid again.
group.sequences.push_back(AnimationSequence::New());
EXPECT_FALSE(IsAnimationGroupValid(group));
AnimationSequence& sequence2 = *(group.sequences[1]);
sequence2.elements.push_back(AnimationElement::New());
AnimationElement& element2 = *(sequence2.elements[0]);
element2.property = AnimationProperty::OPACITY;
element2.tween_type = AnimationTweenType::LINEAR;
// Element with no target_value is not valid.
EXPECT_FALSE(IsAnimationGroupValid(group));
element2.property = AnimationProperty::NONE;
EXPECT_TRUE(IsAnimationGroupValid(group));
}
} // namespace view_manager