mirror of
https://github.com/zhigang1992/react-native.git
synced 2026-04-03 17:45:12 +08:00
Summary: All code styles are terribly ugly. We have the only choise - choise something and embrace it. This particular code style was borrowed from a neibour Fabric-friendly project because it follows established Facebook guides and respects client-side traditions. Reviewed By: mdvacca Differential Revision: D10218598 fbshipit-source-id: 8c4cf6713c07768566dadef479191661c79988f0
47 lines
1.5 KiB
C++
47 lines
1.5 KiB
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 <memory>
|
|
|
|
#include <assert.h>
|
|
#include <fabric/attributedstring/TextAttributes.h>
|
|
#include <fabric/attributedstring/conversions.h>
|
|
#include <fabric/attributedstring/primitives.h>
|
|
#include <fabric/graphics/conversions.h>
|
|
#include <gtest/gtest.h>
|
|
|
|
namespace facebook {
|
|
namespace react {
|
|
|
|
TEST(AttributedStringTest, testSomething) {
|
|
auto attString = new AttributedString();
|
|
auto fragment = new AttributedString::Fragment();
|
|
fragment->string = "test";
|
|
|
|
auto text = new TextAttributes();
|
|
text->foregroundColor = {
|
|
colorFromComponents({100 / 255.0, 153 / 255.0, 200 / 255.0, 1.0})};
|
|
text->opacity = 0.5;
|
|
text->fontStyle = FontStyle::Italic;
|
|
text->fontWeight = FontWeight::Thin;
|
|
text->fontVariant = FontVariant::TabularNums;
|
|
fragment->textAttributes = *text;
|
|
|
|
attString->prependFragment(*fragment);
|
|
|
|
auto result = toDynamic(*attString);
|
|
assert(result["string"] == fragment->string);
|
|
auto textAttribute = result["fragments"][0]["textAttributes"];
|
|
assert(textAttribute["foregroundColor"] == toDynamic(text->foregroundColor));
|
|
assert(textAttribute["opacity"] == text->opacity);
|
|
assert(textAttribute["fontStyle"] == toString(*text->fontStyle));
|
|
assert(textAttribute["fontWeight"] == toString(*text->fontWeight));
|
|
}
|
|
|
|
} // namespace react
|
|
} // namespace facebook
|