mirror of
https://github.com/apache/superset.git
synced 2026-04-16 22:55:52 +00:00
fix: Contribution percentages for ECharts plugins (#28368)
This commit is contained in:
committed by
GitHub
parent
9e4ba6762f
commit
55f3b46f41
@@ -26,37 +26,43 @@ from superset.exceptions import InvalidPostProcessingError
|
||||
from superset.utils.core import DTTM_ALIAS, PostProcessingContributionOrientation
|
||||
from superset.utils.pandas_postprocessing import contribution
|
||||
|
||||
df_template = DataFrame(
|
||||
{
|
||||
DTTM_ALIAS: [
|
||||
datetime(2020, 7, 16, 14, 49),
|
||||
datetime(2020, 7, 16, 14, 50),
|
||||
datetime(2020, 7, 16, 14, 51),
|
||||
],
|
||||
"a": [1, 3, nan],
|
||||
"b": [1, 9, nan],
|
||||
"c": [nan, nan, nan],
|
||||
}
|
||||
)
|
||||
|
||||
def test_contribution():
|
||||
df = DataFrame(
|
||||
{
|
||||
DTTM_ALIAS: [
|
||||
datetime(2020, 7, 16, 14, 49),
|
||||
datetime(2020, 7, 16, 14, 50),
|
||||
datetime(2020, 7, 16, 14, 51),
|
||||
],
|
||||
"a": [1, 3, nan],
|
||||
"b": [1, 9, nan],
|
||||
"c": [nan, nan, nan],
|
||||
}
|
||||
)
|
||||
|
||||
def test_non_numeric_columns():
|
||||
with pytest.raises(InvalidPostProcessingError, match="not numeric"):
|
||||
contribution(df, columns=[DTTM_ALIAS])
|
||||
contribution(df_template.copy(), columns=[DTTM_ALIAS])
|
||||
|
||||
|
||||
def test_rename_should_have_same_length():
|
||||
with pytest.raises(InvalidPostProcessingError, match="same length"):
|
||||
contribution(df, columns=["a"], rename_columns=["aa", "bb"])
|
||||
contribution(df_template.copy(), columns=["a"], rename_columns=["aa", "bb"])
|
||||
|
||||
# cell contribution across row
|
||||
|
||||
def test_cell_contribution_across_row():
|
||||
processed_df = contribution(
|
||||
df,
|
||||
df_template.copy(),
|
||||
orientation=PostProcessingContributionOrientation.ROW,
|
||||
)
|
||||
assert processed_df.columns.tolist() == [DTTM_ALIAS, "a", "b", "c"]
|
||||
assert_array_equal(processed_df["a"].tolist(), [0.5, 0.25, nan])
|
||||
assert_array_equal(processed_df["b"].tolist(), [0.5, 0.75, nan])
|
||||
assert_array_equal(processed_df["c"].tolist(), [0, 0, nan])
|
||||
assert_array_equal(processed_df["c"].tolist(), [nan, nan, nan])
|
||||
|
||||
# cell contribution across column without temporal column
|
||||
|
||||
def test_cell_contribution_across_column_without_temporal_column():
|
||||
df = df_template.copy()
|
||||
df.pop(DTTM_ALIAS)
|
||||
processed_df = contribution(
|
||||
df, orientation=PostProcessingContributionOrientation.COLUMN
|
||||
@@ -66,7 +72,10 @@ def test_contribution():
|
||||
assert_array_equal(processed_df["b"].tolist(), [0.1, 0.9, 0])
|
||||
assert_array_equal(processed_df["c"].tolist(), [nan, nan, nan])
|
||||
|
||||
# contribution only on selected columns
|
||||
|
||||
def test_contribution_on_selected_columns():
|
||||
df = df_template.copy()
|
||||
df.pop(DTTM_ALIAS)
|
||||
processed_df = contribution(
|
||||
df,
|
||||
orientation=PostProcessingContributionOrientation.COLUMN,
|
||||
@@ -78,3 +87,40 @@ def test_contribution():
|
||||
assert_array_equal(processed_df["b"].tolist(), [1, 9, nan])
|
||||
assert_array_equal(processed_df["c"].tolist(), [nan, nan, nan])
|
||||
assert processed_df["pct_a"].tolist() == [0.25, 0.75, 0]
|
||||
|
||||
|
||||
def test_contribution_with_time_shift_columns():
|
||||
df = DataFrame(
|
||||
{
|
||||
DTTM_ALIAS: [
|
||||
datetime(2020, 7, 16, 14, 49),
|
||||
datetime(2020, 7, 16, 14, 50),
|
||||
],
|
||||
"a": [3, 6],
|
||||
"b": [3, 3],
|
||||
"c": [6, 3],
|
||||
"a__1 week ago": [2, 2],
|
||||
"b__1 week ago": [1, 1],
|
||||
"c__1 week ago": [1, 1],
|
||||
}
|
||||
)
|
||||
processed_df = contribution(
|
||||
df,
|
||||
orientation=PostProcessingContributionOrientation.ROW,
|
||||
time_shifts=["1 week ago"],
|
||||
)
|
||||
assert processed_df.columns.tolist() == [
|
||||
DTTM_ALIAS,
|
||||
"a",
|
||||
"b",
|
||||
"c",
|
||||
"a__1 week ago",
|
||||
"b__1 week ago",
|
||||
"c__1 week ago",
|
||||
]
|
||||
assert_array_equal(processed_df["a"].tolist(), [0.25, 0.5])
|
||||
assert_array_equal(processed_df["b"].tolist(), [0.25, 0.25])
|
||||
assert_array_equal(processed_df["c"].tolist(), [0.50, 0.25])
|
||||
assert_array_equal(processed_df["a__1 week ago"].tolist(), [0.5, 0.5])
|
||||
assert_array_equal(processed_df["b__1 week ago"].tolist(), [0.25, 0.25])
|
||||
assert_array_equal(processed_df["c__1 week ago"].tolist(), [0.25, 0.25])
|
||||
|
||||
Reference in New Issue
Block a user