developer_quest

Respository for the I/O 2019 demo: Become a tech lead, slay bugs, and don't get fired.

  • Owner: 2d-inc/developer_quest
  • Platform:
  • License:: MIT License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Developer Quest

Become a tech lead, slay bugs, and don't get fired.

All in Flutter.

Research tree

The game progression is based on a "research tree" of tasks. The tree is defined in code
in lib/src/shared_state/task_tree but for clarity it is also kept as a diagram
in assets/docs. Here's the PNG.

The task "research tree"

Performance testing

Attach a real device and run the following command from the root of the repo:

flutter drive --target=test_driver/performance.dart --profile

This will do an automated run-through of the app, and will save the output to files.

  • Look into to build/walkthrough-*.json files for detailed summaries of each run.
  • Look at test_driver/perf_stats.tsv to compare latest runs with historical data.
  • Run Rscript test_driver/generate-graphs.R (assuming you have R installed) to generate
    boxplots of the latest runs. This will show up as test_driver/*.pdf files.
  • Peruse the raw data file (used by R to generate the boxplots) by opening the
    durations.tsv file. These files contain build and rasterization times for each frame
    for every run.

If you want to get several runs at once, you can use something like the following command:

DESC="my change" bash -c 'for i in {1..5}; do flutter drive --target=test_driver/performance.dart --profile; sleep 1; done'

Why run several times when we get so many data points on each walkthrough? With several identical
walkthroughs it's possible to visually check variance between runs. Even with box plots,
these nuances get lost in the summary stats, so it's hard to see whether a change actually
brought any performance improvement or not. Running several times also eliminates
the effect of extremely bad luck, like for example when Android decides to update some app while
test is running.

Lock CPU and GPU speed for your performance test device

Run the following command when your performance test device is attached via USB.

./tool/lock_android_scaling.sh

WARNING:

Where to store the profiling data

You probably don't want to check the *.tsv output files into the repo. For that,
run git update-index --assume-unchanged test_driver/*.tsv in the root dir. This is a one time
command per machine.

Main metrics

Overview
Name With Owner2d-inc/developer_quest
Primary LanguageDart
Program languageKotlin (Language Count: 6)
Platform
License:MIT License
所有者活动
Created At2019-03-13 22:09:05
Pushed At2021-05-05 10:56:43
Last Commit At2019-12-18 07:55:12
Release Count0
用户参与
Stargazers Count3k
Watchers Count110
Fork Count557
Commits Count504
Has Issues Enabled
Issues Count58
Issue Open Count27
Pull Requests Count84
Pull Requests Open Count8
Pull Requests Close Count10
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private