Summary: X-link: https://github.com/facebook/react-native/pull/44067 X-link: https://github.com/facebook/litho/pull/980 Pull Request resolved: https://github.com/facebook/yoga/pull/1643 Changelog [Internal]: - Added percentage value for flex layout gap - Wired up to pass proper available width and height to implement this feature Reviewed By: NickGerleman Differential Revision: D56002340 fbshipit-source-id: c0bc86ac70a1391f115c87da99c2ef411535f68b
45 lines
1.3 KiB
C++
45 lines
1.3 KiB
C++
/*
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*/
|
|
|
|
#include <gtest/gtest.h>
|
|
#include <yoga/style/Style.h>
|
|
|
|
namespace facebook::yoga {
|
|
|
|
TEST(Style, computed_padding_is_floored) {
|
|
yoga::Style style;
|
|
style.setPadding(Edge::All, value::points(-1.0f));
|
|
auto paddingStart = style.computeInlineStartPadding(
|
|
FlexDirection::Row, Direction::LTR, 0.0f /*widthSize*/);
|
|
ASSERT_EQ(paddingStart, 0.0f);
|
|
}
|
|
|
|
TEST(Style, computed_border_is_floored) {
|
|
yoga::Style style;
|
|
style.setBorder(Edge::All, value::points(-1.0f));
|
|
auto borderStart =
|
|
style.computeInlineStartBorder(FlexDirection::Row, Direction::LTR);
|
|
ASSERT_EQ(borderStart, 0.0f);
|
|
}
|
|
|
|
TEST(Style, computed_gap_is_floored) {
|
|
yoga::Style style;
|
|
style.setGap(Gutter::Column, value::points(-1.0f));
|
|
auto gapBetweenColumns = style.computeGapForAxis(FlexDirection::Row, 0.0);
|
|
ASSERT_EQ(gapBetweenColumns, 0.0f);
|
|
}
|
|
|
|
TEST(Style, computed_margin_is_not_floored) {
|
|
yoga::Style style;
|
|
style.setMargin(Edge::All, value::points(-1.0f));
|
|
auto marginStart = style.computeInlineStartMargin(
|
|
FlexDirection::Row, Direction::LTR, 0.0f /*widthSize*/);
|
|
ASSERT_EQ(marginStart, -1.0f);
|
|
}
|
|
|
|
} // namespace facebook::yoga
|