-
Notifications
You must be signed in to change notification settings - Fork 2k
Codebase Overview
Here are the relevant pieces of TFB's file structure:
- .github/
- workflows/
- PULL_REQUEST_TEMPLATE.md
-
deployment/
- vagrant-development/
- etc...
-
frameworks/
- Java/
- README.md
- dropwizard/
- gemini/
- etc...
- Ruby/
- etc...
- Java/
-
toolset/
-
benchmark/
- benchmarker.py
- framework_test.py
- continuous/
- databases/
- scaffolding/
- github_actions/
- utils/
- wrk/
-
benchmark/
Provides GitHub Actions with the relevant information to test TFB. See the GitHub Actions section for more information.
Information for deploying the benchmark on a range of cloud or self-hosted environments. While you can always use manual deployment, automated scripts exist for many scenarios.
This directory contains all of the framework implementations of the benchmarking suite tests. The general directory structure is Language and then the framework name. The contents for the framework directory range between each framework. However, there are a few files that are similar.
For information on each language, there are individual READMEs within their respective directory.
Because the information for each language varies so much, each language should have its own README. This should include information like which software versions are used, special instructions for adding a new framework in that language, and places where you can get help specific to that language. See the Language README Formatting Guide for a more detailed guide.
Because the information for each framework varies so much, each framework should have its own README. This should include information like which software versions are used, special instructions for adding a new variation in that framework, and places where you can get help specific to that framework. See the Framework README Formatting Guide for a more detailed guide.
Most of the files are framework specific and you can find more information within their individual READMEs. However, there are two files that are required by the TFB suite. These are:
- benchmark_config.json
- [test-name].dockerfile
See the section on Framework Specific Files for more information.
The file named source_code
within each framework is used to count the lines
of code in the project - each file listed in source_code has its lines counted
(we're using CLOC to provide this functionality)
and the result are include in results.json
under the rawData > slocCounts
keys, as shown here:
"rawData": {
"slocCounts": {
"mojolicious": 72,
"scruffy": 47,
"nodejs": 217,
"spring": 242,
"cpoll-cppsp": 82,
"slim": 1889,
"dropwizard": 293,
"revel": 258,
"dancer": 32,
TFB does not use the numbers in any of the graphs but we include them for other consumers of the data.
Note: The keys used are framework names (e.g. ringo) and not the framework test names (e.g. ringojs-raw).
This directory contains the code that TFB uses to automate installing, launching, load testing, and terminating each framework.
This directory contains files that implement or support the benchmark feature:
-
benchmarker.py
: Benchmark execution methods. Called byrun-tests.py
. -
framework_test.py
: Methods to run a framework's tests. Called bybenchmarker.py
.
These files are not meant for you to run directly. For instructions on running the benchmark, please refer to the benchmarking section.
This directory contains the files required to run our continuous benchmarking.
This directory contains the configuration and dockerfiles for the databases we support.
This directory contains a script for quickly bootstrapping a new framework test.
This directory is specifically for the diffing tool used by GitHub Actions.
This directory contains a set of helper utilities used by our benchmarking tool.
Page | Summary |
---|---|
Framework Specific Files | Files specific to each individual framework for use with the benchmarking suite. |
- Home
- Project Information
- Development
- Benchmarking
- Codebase
- About
- Support
- Work in progress