Files
react-native/ReactCommon/fabric/core/tests/PrimitivesTest.cpp
T
Samuel Susla 582738bdc8 Use EXPECT instead of ASSERT in tests
Summary:
Changelog: [Internal]

1. Replace ASSERT_* with EXPECT_*. Assert is a fatal assertion. Expect is non-fatal assertion. So if assert fails, tests do not continue and therefore provide less information.

2. Rename tests in `RawPropsTest.cpp` from `ShadowNodeTest` to `RawPropsTest`.

Source: https://github.com/google/googletest/blob/master/googletest/docs/primer.md#basic-assertions

Reviewed By: shergin

Differential Revision: D19464967

fbshipit-source-id: add83751ebdb0a12fbf8f70b851747aa5624366a
2020-01-20 01:11:50 -08:00

42 lines
974 B
C++

/*
* Copyright (c) Facebook, Inc. and its affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/
#include <exception>
#include <gtest/gtest.h>
#include <react/core/Sealable.h>
using namespace facebook::react;
TEST(SealableTest, sealObjectCorrectly) {
Sealable obj;
EXPECT_FALSE(obj.getSealed());
obj.seal();
EXPECT_TRUE(obj.getSealed());
}
TEST(SealableTest, handleAssignmentsCorrectly) {
Sealable obj;
Sealable other;
EXPECT_NO_THROW(obj = other);
// Assignment after getting sealed is not allowed.
obj.seal();
Sealable other2;
EXPECT_THROW(obj = other2, std::runtime_error);
// It doesn't matter if the other object is also sealed, it's still not
// allowed.
other2.seal();
EXPECT_THROW(obj = other2, std::runtime_error);
// Fresh creation off other Sealable is still unsealed.
Sealable other3(obj);
EXPECT_FALSE(other3.getSealed());
}