-
Notifications
You must be signed in to change notification settings - Fork 901
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add verified tips calculation into notification Add test for GetAmountFromVerifiedAuto Fix lint lint fixes Adding tests Combined tests to create WillTriggerNotification test spacing Updated methods to static
- Loading branch information
Jason Sadler
committed
Apr 13, 2019
1 parent
7886077
commit 9145189
Showing
9 changed files
with
290 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
165 changes: 165 additions & 0 deletions
165
vendor/bat-native-ledger/src/bat/ledger/internal/bat_contribution_unittest.cc
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,165 @@ | ||
/* Copyright (c) 2019 The Brave Authors. All rights reserved. | ||
* This Source Code Form is subject to the terms of the Mozilla Public | ||
* License, v. 2.0. If a copy of the MPL was not distributed with this | ||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */ | ||
|
||
#include <memory> | ||
#include <vector> | ||
|
||
#include "bat/ledger/internal/logging.h" | ||
#include "bat/ledger/internal/bat_contribution.h" | ||
#include "bat/ledger/ledger.h" | ||
#include "testing/gtest/include/gtest/gtest.h" | ||
|
||
// npm run test -- brave_unit_tests --filter=BatContributionTest.* | ||
|
||
namespace braveledger_bat_contribution { | ||
|
||
class BatContributionTest : public testing::Test { | ||
protected: | ||
void GetPublishersForAuto( | ||
ledger::PublisherInfoList* publisher_info_list, | ||
uint32_t iterations, /* total count of publishers */ | ||
uint32_t variation /* total count of verifieds */) { | ||
// Can't have more verified publishers than total publishers | ||
DCHECK(variation <= iterations); | ||
for (uint32_t ix = 0; ix < iterations; ix++) { | ||
std::unique_ptr<ledger::PublisherInfo> publisher_info( | ||
std::make_unique<ledger::PublisherInfo>( | ||
"example" + std::to_string(ix) + ".com")); | ||
publisher_info->verified = ix < variation; | ||
publisher_info->percent = (1.0 / iterations) * 100.0; | ||
publisher_info_list->push_back(*publisher_info); | ||
} | ||
} | ||
|
||
void GetPublishersForRecurring( | ||
ledger::PublisherInfoList* publisher_info_list, | ||
uint32_t iterations, | ||
std::vector<uint32_t> amounts, | ||
uint32_t variation) { | ||
for (uint32_t ix = 0; ix < iterations; ix++) { | ||
std::unique_ptr<ledger::PublisherInfo> publisher_info( | ||
std::make_unique<ledger::PublisherInfo>( | ||
"recurringexample" + std::to_string(ix) + ".com")); | ||
publisher_info->weight = amounts[ix % amounts.size()]; | ||
publisher_info->verified = ix < variation; | ||
publisher_info_list->push_back(*publisher_info); | ||
} | ||
} | ||
|
||
bool WillTriggerNotification( | ||
uint32_t auto_iterations, | ||
uint32_t auto_variations, | ||
double auto_amount_selected, | ||
uint32_t recurring_iterations, | ||
std::vector<uint32_t> recurring_amounts_selected, | ||
uint32_t recurring_variation, | ||
double wallet_balance) { | ||
ledger::PublisherInfoList publisher_info_list_auto; | ||
ledger::PublisherInfoList publisher_info_list_recurring; | ||
GetPublishersForAuto( | ||
&publisher_info_list_auto, auto_iterations, auto_variations); | ||
double total_reconcile_amount = | ||
BatContribution::GetAmountFromVerifiedAuto( | ||
publisher_info_list_auto, auto_amount_selected); | ||
GetPublishersForRecurring( | ||
&publisher_info_list_recurring, | ||
recurring_iterations, | ||
recurring_amounts_selected, | ||
recurring_variation); | ||
total_reconcile_amount += | ||
BatContribution::GetAmountFromVerifiedRecurring( | ||
publisher_info_list_recurring); | ||
return wallet_balance < total_reconcile_amount; | ||
} | ||
}; | ||
|
||
TEST_F(BatContributionTest, GetAmountFromVerifiedAuto) { | ||
ledger::PublisherInfoList publisher_info_list; | ||
|
||
// 10 publishers total with 5 verified and budget of 30 BAT | ||
GetPublishersForAuto(&publisher_info_list, 10, 5); | ||
double amount = | ||
BatContribution::GetAmountFromVerifiedAuto(publisher_info_list, 30); | ||
EXPECT_EQ(amount, 15); | ||
|
||
// 20 publishers total with 10 verified and budget of 30 BAT | ||
publisher_info_list.clear(); | ||
GetPublishersForAuto(&publisher_info_list, 20, 10); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedAuto(publisher_info_list, 30); | ||
EXPECT_EQ(amount, 15); | ||
|
||
// 50 publishers total with 5 verified and budget of 100 BAT | ||
publisher_info_list.clear(); | ||
GetPublishersForAuto(&publisher_info_list, 50, 5); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedAuto(publisher_info_list, 100); | ||
EXPECT_EQ(amount, 10); | ||
|
||
// 100 publishers total with 80 verified and budget of 1478 BAT | ||
publisher_info_list.clear(); | ||
GetPublishersForAuto(&publisher_info_list, 100, 80); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedAuto(publisher_info_list, 1478); | ||
EXPECT_EQ(amount, 1182.40); | ||
|
||
// 100 publishers total with 4 verified and budget of 100 BAT | ||
publisher_info_list.clear(); | ||
GetPublishersForAuto(&publisher_info_list, 100, 4); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedAuto(publisher_info_list, 100); | ||
EXPECT_EQ(amount, 4); | ||
} | ||
|
||
TEST_F(BatContributionTest, GetAmountFromVerifiedRecurring) { | ||
ledger::PublisherInfoList publisher_info_list; | ||
GetPublishersForRecurring(&publisher_info_list, 5, {1, 5, 10}, 2); | ||
double amount = | ||
BatContribution::GetAmountFromVerifiedRecurring(publisher_info_list); | ||
EXPECT_EQ(amount, 6); | ||
|
||
publisher_info_list.clear(); | ||
GetPublishersForRecurring(&publisher_info_list, 7, {1, 5, 10}, 5); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedRecurring(publisher_info_list); | ||
EXPECT_EQ(amount, 22); | ||
|
||
publisher_info_list.clear(); | ||
GetPublishersForRecurring(&publisher_info_list, 10, {5, 10, 20}, 7); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedRecurring(publisher_info_list); | ||
EXPECT_EQ(amount, 75); | ||
|
||
publisher_info_list.clear(); | ||
GetPublishersForRecurring(&publisher_info_list, 10, {10, 20, 50}, 9); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedRecurring(publisher_info_list); | ||
EXPECT_EQ(amount, 240); | ||
|
||
publisher_info_list.clear(); | ||
GetPublishersForRecurring(&publisher_info_list, 5, {1, 5, 10, 20, 50}, 5); | ||
amount = | ||
BatContribution::GetAmountFromVerifiedRecurring(publisher_info_list); | ||
EXPECT_EQ(amount, 86); | ||
} | ||
|
||
TEST_F(BatContributionTest, WillTriggerNotification) { | ||
EXPECT_TRUE(WillTriggerNotification(10, 5, 30, 5, {1, 5, 10}, 2, 20.9)); | ||
EXPECT_FALSE(WillTriggerNotification(10, 5, 30, 5, {1, 5, 10}, 2, 21)); | ||
EXPECT_TRUE(WillTriggerNotification(20, 10, 30, 7, {1, 5, 10}, 5, 36.9)); | ||
EXPECT_FALSE(WillTriggerNotification(20, 10, 30, 7, {1, 5, 10}, 5, 37)); | ||
EXPECT_TRUE(WillTriggerNotification(50, 5, 100, 10, {5, 10, 20}, 7, 84.9)); | ||
EXPECT_FALSE(WillTriggerNotification(50, 5, 100, 10, {5, 10, 20}, 7, 85)); | ||
EXPECT_TRUE(WillTriggerNotification( | ||
100, 80, 1478, 10, {10, 20, 50}, 9, 1422.39)); | ||
EXPECT_FALSE(WillTriggerNotification( | ||
100, 80, 1478, 10, {10, 20, 50}, 9, 1422.40)); | ||
EXPECT_TRUE(WillTriggerNotification( | ||
100, 4, 100, 5, {1, 5, 10, 20, 50}, 5, 89.9)); | ||
EXPECT_FALSE(WillTriggerNotification( | ||
100, 4, 100, 5, {1, 5, 10, 20, 50}, 5, 90)); | ||
} | ||
|
||
} // namespace braveledger_bat_contribution |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters