Skip to content

jimpick/testground

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

209 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

TestGround

⚠️ Heavy WIP. beware of the Dragons πŸ‰..

This repository is incubating the Testground. 🐣

Description

You may have noticed a few test efforts with similar names underway! Testing at scale is a hard problem. We are indeed exploring and experimenting a lot, until we land on an end-to-end solution that works for us.

The Test Ground aims to leverage the learnings and tooling resulting from those efforts to provide a scalable runtime environment for the execution of various types of tests and benchmarks, written in different languages, by different teams, targeting a specific commit of IPFS and/or libp2p, and quantifying its characteristics in terms of performance, resource and network utilisation, stability, interoperability, etc., when compared to other commits.

The Test Ground aims to be tightly integrated with the software engineering practices and tooling the IPFS and libp2p teams rely on.

Team

The current TestGround Team is composed of:

  • @raulk - Lead Architect, Engineer, Developer
  • @daviddias - Engineer, Developer, acting as interim PM for the project
  • @nonsense - Engineer, Developer, TestGround as a Service / Infrastructure Lead
  • @jimpick - Engineer, Developer
  • @stebalien - Engineer, Developer
  • @hacdias - Engineer, Developer
  • you! Yes, you can contribute as well, however, do understand that this is a brand new and fast moving project and so contributing might require extra time to onboard

To learn how this team works together read HOW_WE_WORK

How to use Test Ground

  • Consult the USAGE to learn how to get it running
  • Refer to the SPEC document to understand how it all works.
  • Consult the repo structure below to know where to find the multiple subsystems and test plans of TestGround
β”œβ”€β”€ README.md                       # This file
β”œβ”€β”€ docs                            # Documentation of the project
β”‚Β Β  β”œβ”€β”€ SPEC.md
β”‚Β Β  β”œβ”€β”€ ...
β”œβ”€β”€ main.go                         # TestGround entrypoint file
β”œβ”€β”€ cmd                             # TestGround CLI comamnds
β”‚Β Β  β”œβ”€β”€ all.go
β”‚Β Β  β”œβ”€β”€ ...
β”œβ”€β”€ sdk                             # SDK available to each test plan
β”‚Β Β  β”œβ”€β”€ runtime
β”‚Β Β  └── ...
β”œβ”€β”€ pkg                             # Internals to TestGround
β”‚Β Β  β”œβ”€β”€ api
β”‚Β Β  β”œβ”€β”€ ...
β”œβ”€β”€ manifests                       # Manifests for each test Plan. These exist independent from plans to enable plans to live elsewhere
β”‚Β Β  β”œβ”€β”€ dht.toml
β”‚Β Β  └── smlbench.toml
β”œβ”€β”€ plans                           # The Test Plan. Includes Image to be run, Assertions and more
β”‚Β Β  β”œβ”€β”€ dht
β”‚Β Β  └── smlbench
└── tools                           # ??
    └── src_generate.go

Contributing

If you plan to contribute code, make sure to install the pre-commit tool, which manages our pre-commit hooks for things like linters, go fmt, go vet, etc.

We provide a Makefile rule to facilitate the setup:

$ make pre-commit

This repository falls under the IPFS Code of Conduct.

You can contact us on the freenode #ipfs-dev channel or attend one of our weekly calls.

License

Dual-licensed: MIT, Apache Software License v2, by way of the Permissive License Stack.

About

[🐣 incubating] Interplanetary TestGround

Resources

License

Unknown, MIT licenses found

Licenses found

Unknown
LICENSE-APACHE
MIT
LICENSE-MIT

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

 
 
 

Contributors

Languages

  • Go 92.6%
  • JavaScript 3.4%
  • Shell 2.0%
  • HCL 1.5%
  • Other 0.5%