dash/README.md

82 lines
3.4 KiB
Markdown
Raw Normal View History

Dash Core staging tree 18.0
===========================
|CI|master|develop|
|-|-|-|
|Gitlab|[![Build Status](https://gitlab.com/dashpay/dash/badges/master/pipeline.svg)](https://gitlab.com/dashpay/dash/-/tree/master)|[![Build Status](https://gitlab.com/dashpay/dash/badges/develop/pipeline.svg)](https://gitlab.com/dashpay/dash/-/tree/develop)|
2016-01-31 14:11:16 +01:00
https://www.dash.org
For an immediately usable, binary version of the Dash Core software, see
https://www.dash.org/downloads/.
Further information about Dash Core is available in the [doc folder](/doc).
2014-12-12 12:09:19 +01:00
2015-03-18 00:06:58 +01:00
What is Dash?
-------------
Dash is an experimental digital currency that enables instant, private
2015-03-18 00:06:58 +01:00
payments to anyone, anywhere in the world. Dash uses peer-to-peer technology
2014-12-12 12:09:19 +01:00
to operate with no central authority: managing transactions and issuing money
are carried out collectively by the network. Dash Core is the name of the open
2014-12-12 12:09:19 +01:00
source software which enables the use of this currency.
2014-12-12 12:09:19 +01:00
For more information read the original Dash whitepaper.
License
-------
2015-03-18 00:06:58 +01:00
Dash Core is released under the terms of the MIT license. See [COPYING](COPYING) for more
information or see https://opensource.org/licenses/MIT.
2010-09-23 20:06:50 +02:00
2015-09-24 15:28:07 +02:00
Development Process
-------------------
2011-09-27 04:22:19 +02:00
2016-03-04 08:25:16 +01:00
The `master` branch is meant to be stable. Development is normally done in separate branches.
2016-05-31 06:56:46 +02:00
[Tags](https://github.com/dashpay/dash/tags) are created to indicate new official,
2016-03-04 08:25:16 +01:00
stable release versions of Dash Core.
2010-12-19 16:39:36 +01:00
The contribution workflow is described in [CONTRIBUTING.md](CONTRIBUTING.md)
and useful hints for developers can be found in [doc/developer-notes.md](doc/developer-notes.md).
Testing
-------
Testing and code review is the bottleneck for development; we get more pull
requests than we can review and test on short notice. Please be patient and help out by testing
other people's pull requests, and remember this is a security-critical project where any mistake might cost people
lots of money.
### Automated Testing
2011-09-27 04:22:19 +02:00
Developers are strongly encouraged to write [unit tests](src/test/README.md) for new code, and to
2015-11-18 00:26:07 +01:00
submit new unit tests for old code. Unit tests can be compiled and run
(assuming they weren't disabled in configure) with: `make check`. Further details on running
and extending unit tests can be found in [/src/test/README.md](/src/test/README.md).
There are also [regression and integration tests](/test), written
in Python.
These tests can be run (if the [test dependencies](/test) are installed) with: `test/functional/test_runner.py`
The Travis CI system makes sure that every pull request is built for Windows, Linux, and macOS, and that unit/sanity tests are run automatically.
### Manual Quality Assurance (QA) Testing
Changes should be tested by somebody other than the developer who wrote the
code. This is especially important for large or high-risk changes. It is useful
to add a test plan to the pull request description if testing the changes is
not straightforward.
Translations
------------
Changes to translations as well as new translations can be submitted to
2016-03-04 08:25:16 +01:00
[Dash Core's Transifex page](https://www.transifex.com/projects/p/dash/).
Translations are periodically pulled from Transifex and merged into the git repository. See the
[translation process](doc/translation_process.md) for details on how this works.
**Important**: We do not accept translation changes as GitHub pull requests because the next
pull from Transifex would automatically overwrite them again.