-
-
Notifications
You must be signed in to change notification settings - Fork 450
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
dev: Add RecentMessages benchmark (#5071)
Co-authored-by: Rasmus Karlsson <[email protected]>
- Loading branch information
Showing
22 changed files
with
441 additions
and
114 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,6 @@ | ||
<RCC> | ||
<qresource prefix="/bench"> | ||
<file>recentmessages-nymn.json</file> | ||
<file>seventvemotes-nymn.json</file> | ||
</qresource> | ||
</RCC> |
Large diffs are not rendered by default.
Oops, something went wrong.
Large diffs are not rendered by default.
Oops, something went wrong.
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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,223 @@ | ||
#include "common/Literals.hpp" | ||
#include "controllers/accounts/AccountController.hpp" | ||
#include "controllers/highlights/HighlightController.hpp" | ||
#include "messages/Emote.hpp" | ||
#include "mocks/EmptyApplication.hpp" | ||
#include "mocks/TwitchIrcServer.hpp" | ||
#include "mocks/UserData.hpp" | ||
#include "providers/bttv/BttvEmotes.hpp" | ||
#include "providers/chatterino/ChatterinoBadges.hpp" | ||
#include "providers/ffz/FfzBadges.hpp" | ||
#include "providers/ffz/FfzEmotes.hpp" | ||
#include "providers/recentmessages/Impl.hpp" | ||
#include "providers/seventv/SeventvBadges.hpp" | ||
#include "providers/seventv/SeventvEmotes.hpp" | ||
#include "providers/twitch/TwitchChannel.hpp" | ||
#include "singletons/Emotes.hpp" | ||
#include "singletons/Resources.hpp" | ||
|
||
#include <benchmark/benchmark.h> | ||
#include <QFile> | ||
#include <QJsonArray> | ||
#include <QJsonDocument> | ||
#include <QString> | ||
|
||
#include <optional> | ||
|
||
using namespace chatterino; | ||
using namespace literals; | ||
|
||
namespace { | ||
|
||
class MockApplication : mock::EmptyApplication | ||
{ | ||
public: | ||
IEmotes *getEmotes() override | ||
{ | ||
return &this->emotes; | ||
} | ||
|
||
IUserDataController *getUserData() override | ||
{ | ||
return &this->userData; | ||
} | ||
|
||
AccountController *getAccounts() override | ||
{ | ||
return &this->accounts; | ||
} | ||
|
||
ITwitchIrcServer *getTwitch() override | ||
{ | ||
return &this->twitch; | ||
} | ||
|
||
ChatterinoBadges *getChatterinoBadges() override | ||
{ | ||
return &this->chatterinoBadges; | ||
} | ||
|
||
FfzBadges *getFfzBadges() override | ||
{ | ||
return &this->ffzBadges; | ||
} | ||
|
||
SeventvBadges *getSeventvBadges() override | ||
{ | ||
return &this->seventvBadges; | ||
} | ||
|
||
HighlightController *getHighlights() override | ||
{ | ||
return &this->highlights; | ||
} | ||
|
||
AccountController accounts; | ||
Emotes emotes; | ||
mock::UserDataController userData; | ||
mock::MockTwitchIrcServer twitch; | ||
ChatterinoBadges chatterinoBadges; | ||
FfzBadges ffzBadges; | ||
SeventvBadges seventvBadges; | ||
HighlightController highlights; | ||
}; | ||
|
||
std::optional<QJsonDocument> tryReadJsonFile(const QString &path) | ||
{ | ||
QFile file(path); | ||
if (!file.open(QFile::ReadOnly)) | ||
{ | ||
return std::nullopt; | ||
} | ||
|
||
QJsonParseError e; | ||
auto doc = QJsonDocument::fromJson(file.readAll(), &e); | ||
if (e.error != QJsonParseError::NoError) | ||
{ | ||
return std::nullopt; | ||
} | ||
|
||
return doc; | ||
} | ||
|
||
QJsonDocument readJsonFile(const QString &path) | ||
{ | ||
auto opt = tryReadJsonFile(path); | ||
if (!opt) | ||
{ | ||
_exit(1); | ||
} | ||
return *opt; | ||
} | ||
|
||
class RecentMessages | ||
{ | ||
public: | ||
explicit RecentMessages(const QString &name_) | ||
: name(name_) | ||
, chan(this->name) | ||
{ | ||
const auto seventvEmotes = | ||
tryReadJsonFile(u":/bench/seventvemotes-%1.json"_s.arg(this->name)); | ||
const auto bttvEmotes = | ||
tryReadJsonFile(u":/bench/bttvemotes-%1.json"_s.arg(this->name)); | ||
const auto ffzEmotes = | ||
tryReadJsonFile(u":/bench/ffzemotes-%1.json"_s.arg(this->name)); | ||
|
||
if (seventvEmotes) | ||
{ | ||
this->chan.setSeventvEmotes( | ||
std::make_shared<const EmoteMap>(seventv::detail::parseEmotes( | ||
seventvEmotes->object()["emote_set"_L1] | ||
.toObject()["emotes"_L1] | ||
.toArray(), | ||
false))); | ||
} | ||
|
||
if (bttvEmotes) | ||
{ | ||
this->chan.setBttvEmotes(std::make_shared<const EmoteMap>( | ||
bttv::detail::parseChannelEmotes(bttvEmotes->object(), | ||
this->name))); | ||
} | ||
|
||
if (ffzEmotes) | ||
{ | ||
this->chan.setFfzEmotes(std::make_shared<const EmoteMap>( | ||
ffz::detail::parseChannelEmotes(ffzEmotes->object()))); | ||
} | ||
|
||
this->messages = | ||
readJsonFile(u":/bench/recentmessages-%1.json"_s.arg(this->name)); | ||
} | ||
|
||
~RecentMessages() | ||
{ | ||
QCoreApplication::sendPostedEvents(nullptr, QEvent::DeferredDelete); | ||
} | ||
|
||
virtual void run(benchmark::State &state) = 0; | ||
|
||
protected: | ||
QString name; | ||
MockApplication app; | ||
TwitchChannel chan; | ||
QJsonDocument messages; | ||
}; | ||
|
||
class ParseRecentMessages : public RecentMessages | ||
{ | ||
public: | ||
explicit ParseRecentMessages(const QString &name_) | ||
: RecentMessages(name_) | ||
{ | ||
} | ||
|
||
void run(benchmark::State &state) | ||
{ | ||
for (auto _ : state) | ||
{ | ||
auto parsed = recentmessages::detail::parseRecentMessages( | ||
this->messages.object()); | ||
benchmark::DoNotOptimize(parsed); | ||
} | ||
} | ||
}; | ||
|
||
class BuildRecentMessages : public RecentMessages | ||
{ | ||
public: | ||
explicit BuildRecentMessages(const QString &name_) | ||
: RecentMessages(name_) | ||
{ | ||
} | ||
|
||
void run(benchmark::State &state) | ||
{ | ||
auto parsed = recentmessages::detail::parseRecentMessages( | ||
this->messages.object()); | ||
for (auto _ : state) | ||
{ | ||
auto built = recentmessages::detail::buildRecentMessages( | ||
parsed, &this->chan); | ||
benchmark::DoNotOptimize(built); | ||
} | ||
} | ||
}; | ||
|
||
void BM_ParseRecentMessages(benchmark::State &state, const QString &name) | ||
{ | ||
ParseRecentMessages bench(name); | ||
bench.run(state); | ||
} | ||
|
||
void BM_BuildRecentMessages(benchmark::State &state, const QString &name) | ||
{ | ||
BuildRecentMessages bench(name); | ||
bench.run(state); | ||
} | ||
|
||
} // namespace | ||
|
||
BENCHMARK_CAPTURE(BM_ParseRecentMessages, nymn, u"nymn"_s); | ||
BENCHMARK_CAPTURE(BM_BuildRecentMessages, nymn, u"nymn"_s); |
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
Oops, something went wrong.