Fix issue with leaderboard position due to wrong calculation of trend
This commit is contained in:
parent
1fb247c675
commit
559e88d9e6
6 changed files with 115 additions and 163 deletions
|
@ -174,12 +174,12 @@ test_leaderboard(
|
|||
'daily_total',
|
||||
$now,
|
||||
[
|
||||
{ display_name => 'Test User4', value => 9, trend => 1 },
|
||||
{ display_name => 'Test User3', value => 5, trend => 0 },
|
||||
{ display_name => 'Test User2', value => 3, trend => 1 },
|
||||
{ display_name => 'Test User1', value => 1, trend => -1},
|
||||
{ display_name => 'Test User4', value => 9, position => 1, trend => -1 },
|
||||
{ display_name => 'Test User3', value => 5, position => 2, trend => 0 },
|
||||
{ display_name => 'Test User2', value => 3, position => 3, trend => -1 },
|
||||
{ display_name => 'Test User1', value => 1, position => 4, trend => 1},
|
||||
],
|
||||
3
|
||||
4
|
||||
);
|
||||
|
||||
test_leaderboard(
|
||||
|
@ -187,12 +187,12 @@ test_leaderboard(
|
|||
'daily_count',
|
||||
$now,
|
||||
[
|
||||
{ display_name => 'Test User1', value => 1, trend => 0 },
|
||||
{ display_name => 'Test User2', value => 1, trend => 0 },
|
||||
{ display_name => 'Test User3', value => 1, trend => 0 },
|
||||
{ display_name => 'Test User4', value => 1, trend => 0 },
|
||||
{ display_name => 'Test User1', value => 1, position => 1, trend => 0 },
|
||||
{ display_name => 'Test User2', value => 1, position => 2, trend => 0 },
|
||||
{ display_name => 'Test User3', value => 1, position => 3, trend => 0 },
|
||||
{ display_name => 'Test User4', value => 1, position => 4, trend => 0 },
|
||||
],
|
||||
0
|
||||
1
|
||||
);
|
||||
|
||||
done_testing;
|
||||
|
|
|
@ -161,7 +161,7 @@ sub test_leaderboard {
|
|||
{},
|
||||
{
|
||||
order_by => { -desc => 'value' },
|
||||
columns => [ qw/ user_id value trend / ],
|
||||
columns => [ qw/ user_id value trend position / ],
|
||||
},
|
||||
);
|
||||
$today_values->result_class( 'DBIx::Class::ResultClass::HashRefInflator' );
|
||||
|
@ -177,10 +177,10 @@ test_leaderboard(
|
|||
'daily_total',
|
||||
$now,
|
||||
[
|
||||
{ user_id => 4, value => 9, trend => 1 },
|
||||
{ user_id => 3, value => 5, trend => 0 },
|
||||
{ user_id => 2, value => 3, trend => 1 },
|
||||
{ user_id => 1, value => 1, trend => -1},
|
||||
{ user_id => 4, value => 9, trend => -1, position => 1},
|
||||
{ user_id => 3, value => 5, trend => 0, position => 2},
|
||||
{ user_id => 2, value => 3, trend => -1, position => 3},
|
||||
{ user_id => 1, value => 1, trend => 1, position => 4},
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -189,10 +189,10 @@ test_leaderboard(
|
|||
'daily_count',
|
||||
$now,
|
||||
[
|
||||
{ user_id => 1, value => 1, trend => 0 },
|
||||
{ user_id => 2, value => 1, trend => 0 },
|
||||
{ user_id => 3, value => 1, trend => 0 },
|
||||
{ user_id => 4, value => 1, trend => 0 },
|
||||
{ user_id => 1, value => 1, trend => 0, position => 1 },
|
||||
{ user_id => 2, value => 1, trend => 0, position => 2 },
|
||||
{ user_id => 3, value => 1, trend => 0, position => 3 },
|
||||
{ user_id => 4, value => 1, trend => 0, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
|
|
@ -131,7 +131,7 @@ sub test_leaderboard {
|
|||
{},
|
||||
{
|
||||
order_by => { -desc => 'value' },
|
||||
columns => [ qw/ user_id value / ],
|
||||
columns => [ qw/ user_id value position / ],
|
||||
},
|
||||
);
|
||||
$today_values->result_class( 'DBIx::Class::ResultClass::HashRefInflator' );
|
||||
|
@ -145,10 +145,10 @@ test_leaderboard(
|
|||
'daily_total',
|
||||
$now,
|
||||
[
|
||||
{ user_id => 4, value => 95 },
|
||||
{ user_id => 3, value => 85 },
|
||||
{ user_id => 2, value => 75 },
|
||||
{ user_id => 1, value => 65 },
|
||||
{ user_id => 4, value => 95, position => 1 },
|
||||
{ user_id => 3, value => 85, position => 2 },
|
||||
{ user_id => 2, value => 75, position => 3 },
|
||||
{ user_id => 1, value => 65, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -157,10 +157,10 @@ test_leaderboard(
|
|||
'daily_count',
|
||||
$now,
|
||||
[
|
||||
{ user_id => 1, value => 10 },
|
||||
{ user_id => 2, value => 10 },
|
||||
{ user_id => 3, value => 10 },
|
||||
{ user_id => 4, value => 10 },
|
||||
{ user_id => 1, value => 10, position => 1 },
|
||||
{ user_id => 2, value => 10, position => 2 },
|
||||
{ user_id => 3, value => 10, position => 3 },
|
||||
{ user_id => 4, value => 10, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -169,10 +169,10 @@ test_leaderboard(
|
|||
'weekly_total',
|
||||
$now->clone->subtract( days => 7 ),
|
||||
[
|
||||
{ user_id => 4, value => 195 },
|
||||
{ user_id => 3, value => 185 },
|
||||
{ user_id => 2, value => 175 },
|
||||
{ user_id => 1, value => 165 },
|
||||
{ user_id => 4, value => 195, position => 1 },
|
||||
{ user_id => 3, value => 185, position => 2 },
|
||||
{ user_id => 2, value => 175, position => 3 },
|
||||
{ user_id => 1, value => 165, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -181,10 +181,10 @@ test_leaderboard(
|
|||
'weekly_count',
|
||||
$now->clone->subtract( days => 7 ),
|
||||
[
|
||||
{ user_id => 1, value => 10 },
|
||||
{ user_id => 2, value => 10 },
|
||||
{ user_id => 3, value => 10 },
|
||||
{ user_id => 4, value => 10 },
|
||||
{ user_id => 1, value => 10, position => 1 },
|
||||
{ user_id => 2, value => 10, position => 2 },
|
||||
{ user_id => 3, value => 10, position => 3 },
|
||||
{ user_id => 4, value => 10, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -193,10 +193,10 @@ test_leaderboard(
|
|||
'monthly_total',
|
||||
$now->clone->subtract( months => 1 ),
|
||||
[
|
||||
{ user_id => 4, value => 490 },
|
||||
{ user_id => 3, value => 470 },
|
||||
{ user_id => 2, value => 450 },
|
||||
{ user_id => 1, value => 430 },
|
||||
{ user_id => 4, value => 490, position => 1 },
|
||||
{ user_id => 3, value => 470, position => 2 },
|
||||
{ user_id => 2, value => 450, position => 3 },
|
||||
{ user_id => 1, value => 430, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -205,10 +205,10 @@ test_leaderboard(
|
|||
'monthly_count',
|
||||
$now->clone->subtract( months => 1 ),
|
||||
[
|
||||
{ user_id => 1, value => 20 },
|
||||
{ user_id => 2, value => 20 },
|
||||
{ user_id => 3, value => 20 },
|
||||
{ user_id => 4, value => 20 },
|
||||
{ user_id => 1, value => 20, position => 1 },
|
||||
{ user_id => 2, value => 20, position => 2 },
|
||||
{ user_id => 3, value => 20, position => 3 },
|
||||
{ user_id => 4, value => 20, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -217,10 +217,10 @@ test_leaderboard(
|
|||
'all_time_total',
|
||||
$now,
|
||||
[
|
||||
{ user_id => 4, value => 980 },
|
||||
{ user_id => 3, value => 940 },
|
||||
{ user_id => 2, value => 900 },
|
||||
{ user_id => 1, value => 860 },
|
||||
{ user_id => 4, value => 980, position => 1 },
|
||||
{ user_id => 3, value => 940, position => 2 },
|
||||
{ user_id => 2, value => 900, position => 3 },
|
||||
{ user_id => 1, value => 860, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -229,10 +229,10 @@ test_leaderboard(
|
|||
'all_time_count',
|
||||
$now,
|
||||
[
|
||||
{ user_id => 1, value => 40 },
|
||||
{ user_id => 2, value => 40 },
|
||||
{ user_id => 3, value => 40 },
|
||||
{ user_id => 4, value => 40 },
|
||||
{ user_id => 1, value => 40, position => 1 },
|
||||
{ user_id => 2, value => 40, position => 2 },
|
||||
{ user_id => 3, value => 40, position => 3 },
|
||||
{ user_id => 4, value => 40, position => 4 },
|
||||
]
|
||||
);
|
||||
|
||||
|
@ -250,16 +250,16 @@ subtest 'get_latest' => sub {
|
|||
{},
|
||||
{
|
||||
order_by => { -desc => 'value' },
|
||||
columns => [ qw/ user_id value / ],
|
||||
columns => [ qw/ user_id value position / ],
|
||||
},
|
||||
);
|
||||
$today_values->result_class( 'DBIx::Class::ResultClass::HashRefInflator' );
|
||||
|
||||
my $expected = [
|
||||
{ user_id => 4, value => 95 },
|
||||
{ user_id => 3, value => 85 },
|
||||
{ user_id => 2, value => 75 },
|
||||
{ user_id => 1, value => 65 },
|
||||
{ user_id => 4, value => 95, position => 1 },
|
||||
{ user_id => 3, value => 85, position => 2 },
|
||||
{ user_id => 2, value => 75, position => 3 },
|
||||
{ user_id => 1, value => 65, position => 4 },
|
||||
];
|
||||
|
||||
is_deeply [ $today_values->all ], $expected, 'array as expected';
|
||||
|
|
Reference in a new issue