コード例 #1
0
def test_single_metrics_in_multiple_experiment(dao, checks, unit_type):
    experiment = Experiment(
        "test-multiple",
        "a",
        [
            Metric(
                1,
                "Click-through Rate",
                "count(test_unit_type.unit.click)",
                "count(test_unit_type.global.exposure)",
            ),
            Metric(
                2,
                "Average Bookings",
                "value(test_unit_type.unit.conversion)",
                "count(test_unit_type.global.exposure)",
            ),
            Metric(
                3,
                "Conversion Rate",
                "count(test_unit_type.unit.conversion)",
                "count(test_unit_type.global.exposure)",
            ),
        ],
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #2
0
def test_srm_one_variant(dao, metrics, checks):
    experiment = Experiment("test-srm-one-variant",
                            "a",
                            metrics,
                            checks,
                            unit_type="test_unit_type")
    evaluate_experiment_agg(experiment, dao)
コード例 #3
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_single_metrics_in_multiple_experiment(dao, checks, unit_type):
    experiment = Experiment(
        'test-multiple',
        'a',
        [
            Metric(
                1,
                'Click-through Rate',
                'count(test_unit_type.unit.click)',
                'count(test_unit_type.global.exposure)',
            ),
            Metric(
                2,
                'Average Bookings',
                'value(test_unit_type.unit.conversion)',
                'count(test_unit_type.global.exposure)',
            ),
            Metric(
                3,
                'Conversion Rate',
                'count(test_unit_type.unit.conversion)',
                'count(test_unit_type.global.exposure)',
            ),
        ],
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #4
0
def test_srm_one_variant(dao, metrics, checks):
    experiment = Experiment('test-srm-one-variant',
                            'a',
                            metrics,
                            checks,
                            unit_type='test_unit_type')
    evaluate_experiment_agg(experiment, dao)
コード例 #5
0
def test_srm_negative(dao, metrics, checks):
    experiment = Experiment("test-srm-negative",
                            "a",
                            metrics,
                            checks,
                            unit_type="test_unit_type")
    evaluate_experiment_agg(experiment, dao)
コード例 #6
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_binary_valued(dao, metrics, checks, unit_type):
    experiment = Experiment('test-conversion',
                            'a',
                            metrics,
                            checks,
                            unit_type=unit_type)
    evaluate_experiment_agg(experiment, dao)
コード例 #7
0
def test_srm_negative(dao, metrics, checks):
    experiment = Experiment('test-srm-negative',
                            'a',
                            metrics,
                            checks,
                            unit_type='test_unit_type')
    evaluate_experiment_agg(experiment, dao)
コード例 #8
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_single_metric_in_multiple_experiment_2(dao, metrics, checks,
                                                unit_type):
    experiment = Experiment('test-multiple',
                            'a',
                            metrics,
                            checks,
                            unit_type=unit_type)
    evaluate_experiment_agg(experiment, dao)
コード例 #9
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_missing_default_value(dao, metrics, checks, unit_type):
    experiment = Experiment(
        'test-missing-default-value',
        'a',
        metrics,
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #10
0
def test_missing_all_value(dao, metrics, checks, unit_type):
    experiment = Experiment(
        "test-missing-all-value",
        "a",
        metrics,
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #11
0
def test_missing_default_exposure(dao, metrics, checks, unit_type):
    experiment = Experiment(
        "test-missing-default-exposure",
        "a",
        metrics,
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #12
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_bad_experiment_unit(dao, metrics, checks, unit_type):
    experiment = Experiment(
        'bad-experiment-unit',
        'a',
        metrics,
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #13
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_missing_all(dao, metrics, checks, unit_type):
    experiment = Experiment(
        'test-missing-all',
        'a',
        metrics,
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #14
0
def test_missing_variant(dao, metrics, checks, unit_type):
    experiment = Experiment(
        "test-missing-variant",
        "a",
        metrics,
        checks,
        unit_type=unit_type,
        variants=["a", "b"],
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #15
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_missing_variant(dao, metrics, checks, unit_type):
    experiment = Experiment(
        'test-missing-variant',
        'a',
        metrics,
        checks,
        unit_type=unit_type,
        variants=['a', 'b'],
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #16
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_single_metric_in_multiple_experiment_1(dao, checks, unit_type):
    experiment = Experiment(
        'test-multiple',
        'a',
        [
            Metric(
                2,
                'Average Bookings',
                'value(test_unit_type.unit.conversion)',
                'count(test_unit_type.global.exposure)',
            )
        ],
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #17
0
def test_unique(dao, unit_type):
    experiment = Experiment(
        "test-unique",
        "a",
        [
            Metric(
                1,
                "Unique Click-through Rate",
                "unique(test_unit_type.unit.click)",
                "count(test_unit_type.global.exposure)",
            )
        ],
        [],  # No check
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #18
0
def test_real_valued(dao, checks, unit_type):
    experiment = Experiment(
        "test-real-valued",
        "a",
        [
            Metric(
                2,
                "Average Bookings",
                "value(test_unit_type.unit.conversion)",
                "count(test_unit_type.global.exposure)",
            )
        ],
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #19
0
def test_single_metric_in_multiple_experiment_1(dao, checks, unit_type):
    experiment = Experiment(
        "test-multiple",
        "a",
        [
            Metric(
                2,
                "Average Bookings",
                "value(test_unit_type.unit.conversion)",
                "count(test_unit_type.global.exposure)",
            )
        ],
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #20
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_real_valued(dao, checks, unit_type):
    experiment = Experiment(
        'test-real-valued',
        'a',
        [
            Metric(
                2,
                'Average Bookings',
                'value(test_unit_type.unit.conversion)',
                'count(test_unit_type.global.exposure)',
            )
        ],
        checks,
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #21
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_unique(dao, unit_type):
    experiment = Experiment(
        'test-unique',
        'a',
        [
            Metric(
                1,
                'Unique Click-through Rate',
                'unique(test_unit_type.unit.click)',
                'count(test_unit_type.global.exposure)',
            )
        ],
        [],  # No check
        unit_type=unit_type,
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #22
0
ファイル: test_experiment.py プロジェクト: baradrb/ep-stats
def test_missing_data_unique_goal(dao, metrics, checks, unit_type):
    experiment = Experiment(
        'test-missing-data-unique-goal',
        'a',
        [
            Metric(
                1,
                'Unique Click-through Rate',
                'unique(test_unit_type.unit.click)',
                'count(test_unit_type.global.exposure)',
            )
        ],
        [SrmCheck(1, 'SRM', 'count(test_unit_type.global.exposure)')],
        unit_type=unit_type,
        variants=['a', 'b'],
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #23
0
def test_missing_data_unique_goal(dao, metrics, checks, unit_type):
    experiment = Experiment(
        "test-missing-data-unique-goal",
        "a",
        [
            Metric(
                1,
                "Unique Click-through Rate",
                "unique(test_unit_type.unit.click)",
                "count(test_unit_type.global.exposure)",
            )
        ],
        [SrmCheck(1, "SRM", "count(test_unit_type.global.exposure)")],
        unit_type=unit_type,
        variants=["a", "b"],
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #24
0
def test_filter_scope_goal(dao, metrics, checks, unit_type):
    experiment = Experiment(
        "test-dimension",
        "a",
        [
            Metric(
                1,
                "Views per User of Screen S",
                "count(test_unit_type.unit.view)",
                "count(test_unit_type.global.exposure)",
            ),
        ],
        [SrmCheck(1, "SRM", "count(test_unit_type.global.exposure)")],
        unit_type=unit_type,
        variants=["a", "b"],
        filters=[Filter("element", ["button-1"], FilterScope.goal)],
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #25
0
def test_degrees_of_freedom(dao, metrics, checks, unit_type):
    """Testing functions np.round() and np.trunc() used when converting degrees of freedom from float to int."""
    experiment = Experiment(
        "test-degrees-of-freedom",
        "a",
        [
            Metric(
                1,
                "Click-through Rate",
                "count(test_unit_type.unit.click)",
                "count(test_unit_type.global.exposure)",
            ),
        ],
        [SrmCheck(1, "SRM", "count(test_unit_type.global.exposure)")],
        unit_type=unit_type,
        variants=["a", "b"],
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #26
0
def test_sequential_today(dao, unit_type):
    """Param date_for is not set - it is set in __init__ method to today"""
    experiment = Experiment(
        "test-sequential-v3",
        "a",
        [
            Metric(
                1,
                "Average Bookings",
                "value(test_unit_type.unit.conversion)",
                "count(test_unit_type.global.exposure)",
            )
        ],
        [],
        unit_type=unit_type,
        date_from="2020-01-01",
        date_to="2020-01-14",
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #27
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_sequential_today(dao, unit_type):
    """Param date_for is not set - it is set in __init__ method to today"""
    experiment = Experiment(
        'test-sequential-v3',
        'a',
        [
            Metric(
                1,
                'Average Bookings',
                'value(test_unit_type.unit.conversion)',
                'count(test_unit_type.global.exposure)',
            )
        ],
        [],
        unit_type=unit_type,
        date_from='2020-01-01',
        date_to='2020-01-14',
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #28
0
def test_sequential_last_day(dao, unit_type):
    """Param date_for equals to param date_to"""
    experiment = Experiment(
        "test-sequential-v3",
        "a",
        [
            Metric(
                1,
                "Average Bookings",
                "value(test_unit_type.unit.conversion)",
                "count(test_unit_type.global.exposure)",
            )
        ],
        [],
        unit_type=unit_type,
        date_from="2020-01-01",
        date_to="2020-01-14",
        date_for="2020-01-14",
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #29
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_sequential_middle(dao, unit_type):
    """Param date_for is set between params date_from and date_to"""
    experiment = Experiment(
        'test-sequential-v2',
        'a',
        [
            Metric(
                1,
                'Average Bookings',
                'value(test_unit_type.unit.conversion)',
                'count(test_unit_type.global.exposure)',
            )
        ],
        [],
        unit_type=unit_type,
        date_from='2020-01-01',
        date_to='2020-01-14',
        date_for='2020-01-10',
    )
    evaluate_experiment_agg(experiment, dao)
コード例 #30
0
ファイル: test_experiment.py プロジェクト: ondraz/ep-stats
def test_sequential_last_day(dao, unit_type):
    """Param date_for equals to param date_to"""
    experiment = Experiment(
        'test-sequential-v3',
        'a',
        [
            Metric(
                1,
                'Average Bookings',
                'value(test_unit_type.unit.conversion)',
                'count(test_unit_type.global.exposure)',
            )
        ],
        [],
        unit_type=unit_type,
        date_from='2020-01-01',
        date_to='2020-01-14',
        date_for='2020-01-14',
    )
    evaluate_experiment_agg(experiment, dao)