remix-project mirror
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
remix-project/README.md

290 lines
10 KiB

2 years ago
<p align="center">
<img src="./apps/remix-ide/src/assets/img/icon.png" alt="Remix Logo" width="200"/>
</p>
2 years ago
<h3 align="center">Remix Project</h3>
<div align="center">
2 years ago
[![CircleCI](https://img.shields.io/circleci/build/github/ethereum/remix-project?logo=circleci)](https://circleci.com/gh/ethereum/remix-project)
[![Documentation Status](https://readthedocs.org/projects/remix-ide/badge/?version=latest)](https://remix-ide.readthedocs.io/en/latest/index.html)
[![contributions welcome](https://img.shields.io/badge/contributions-welcome-brightgreen.svg?style=flat&logo=github)](https://github.com/ethereum/remix-project/blob/master/CONTRIBUTING.md)
[![GitHub contributors](https://img.shields.io/github/contributors/ethereum/remix-project?style=flat&logo=github)](https://github.com/ethereum/remix-project/blob/master/CONTRIBUTING.md)
[![Awesome Remix](https://img.shields.io/badge/Awesome--Remix-resources-green?logo=awesomelists)](https://github.com/ethereum/awesome-remix)
3 years ago
![GitHub](https://img.shields.io/github/license/ethereum/remix-project)
2 years ago
[![Gitter Chat](https://img.shields.io/badge/Gitter%20-chat-brightgreen?style=plastic&logo=gitter)](https://gitter.im/ethereum/remix)
[![Twitter Follow](https://img.shields.io/twitter/follow/ethereumremix?style=flat&logo=twitter&color=green)](https://twitter.com/ethereumremix)
</div>
2 years ago
## Remix Project
**Remix Project** is a rich toolset including Remix IDE, a comprehensive smart contract development tool. The Remix Project also includes Remix Plugin Engine and Remix Libraries which are low-level tools for wider use.
## Remix IDE
**Remix IDE** is used for the entire journey of contract development by users of any knowledge level. It fosters a fast development cycle and has a rich set of plugins with intuitive GUIs. The IDE comes in 2 flavors and a VSCode extension:
**Remix Online IDE**, see: [https://remix.ethereum.org](https://remix.ethereum.org)
:point_right: Supported browsers: Firefox v100.0.1 & Chrome v101.0.4951.64. No support for Remix's use on tablets or smartphones or telephones.
**Remix Desktop IDE**, see releases: [https://github.com/ethereum/remix-desktop/releases](https://github.com/ethereum/remix-desktop/releases)
![Remix screenshot](https://github.com/ethereum/remix-project/raw/master/apps/remix-ide/remix-screenshot-400h.png)
**VSCode extension**, see: [Ethereum-Remix](https://marketplace.visualstudio.com/items?itemName=RemixProject.ethereum-remix)
## Remix libraries
Remix libraries are essential for Remix IDE's native plugins. Read more about libraries [here](libs/README.md)
## Offline Usage
The `gh-pages` branch of [remix-live](https://github.com/ethereum/remix-live) always has the latest stable build of Remix. It contains a ZIP file with the entire build. Download it to use offline.
Note: It contains the latest supported version of Solidity available at the time of the packaging. Other compiler versions can be used online only.
## Setup
* Install **Yarn** and **Node.js**. See [Guide for NodeJs](https://docs.npmjs.com/downloading-and-installing-node-js-and-npm) and [Yarn install](https://classic.yarnpkg.com/lang/en/docs/install)<br/>
3 years ago
*Supported versions:*
```bash
"engines": {
"node": "^20.0.0",
3 years ago
"npm": "^6.14.15"
}
```
* Install [Nx CLI](https://nx.dev/using-nx/nx-cli) globally to enable running **nx executable commands**.
```bash
yarn global add nx
```
* Clone the GitHub repository (`wget` need to be installed first):
```bash
git clone https://github.com/ethereum/remix-project.git
```
3 years ago
* Build `remix-project`:
```bash
cd remix-project
3 years ago
yarn install
3 years ago
yarn run build:libs // Build remix libs
3 years ago
nx build
nx serve
```
3 years ago
Open `http://127.0.0.1:8080` in your browser to load Remix IDE locally.
Go to your `text editor` and start developing. The browser will automatically refresh when files are saved.
## Production Build
To generate react production builds for remix-project.
```bash
3 years ago
yarn run build:production
```
3 years ago
Build can be found in `remix-project/dist/apps/remix-ide` directory.
```bash
3 years ago
yarn run serve:production
```
3 years ago
Production build will be served by default to `http://localhost:8080/` or `http://127.0.0.1:8080/`
## Docker:
Prerequisites:
* Docker (https://docs.docker.com/desktop/)
* Docker Compose (https://docs.docker.com/compose/install/)
### Run with docker
If you want to run the latest changes that are merged into the master branch then run:
```
docker pull remixproject/remix-ide:latest
docker run -p 8080:80 remixproject/remix-ide:latest
```
If you want to run the latest remix-live release run.
```
docker pull remixproject/remix-ide:remix_live
docker run -p 8080:80 remixproject/remix-ide:remix_live
```
### Run with docker-compose:
To run locally without building you only need docker-compose.yaml file and you can run:
```
docker-compose pull
docker-compose up -d
```
Then go to http://localhost:8080 and you can use your Remix instance.
To fetch the docker-compose file without cloning this repo run:
```
curl https://raw.githubusercontent.com/ethereum/remix-project/master/docker-compose.yaml > docker-compose.yaml
```
3 years ago
### Troubleshooting
If you have trouble building the project, make sure that you have the correct version of `node`, `npm` and `nvm`. Also, ensure [Nx CLI](https://nx.dev/using-nx/nx-cli) is installed globally.
Run:
```bash
node --version
npm --version
nvm --version
```
In Debian-based OS such as Ubuntu 14.04LTS, you may need to run `apt-get install build-essential`. After installing `build-essential`, run `npm rebuild`.
## Unit Testing
3 years ago
Run the unit tests using library name like: `nx test <project-name>`
3 years ago
For example, to run unit tests of `remix-analyzer`, use `nx test remix-analyzer`
## Browser Testing
To run the Selenium tests via Nightwatch:
- Install Selenium for the first time: `yarn run selenium-install`
3 years ago
- Run a selenium server: `yarn run selenium`
3 years ago
- Build & Serve Remix: `nx serve`
- Run all the end-to-end tests:
3 years ago
for Firefox: `yarn run nightwatch_local_firefox`, or
3 years ago
3 years ago
for Google Chrome: `yarn run nightwatch_local_chrome`
3 years ago
- Run a specific test case instead, use a command like this:
3 years ago
- yarn run nightwatch_local_ballot
3 years ago
The package.json file contains a list of all the tests you can run.
**NOTE:**
- **The `ballot` tests suite** requires running `ganache-cli` locally.
- **The `remixd` tests suite** requires running `remixd` locally.
3 years ago
- **The `gist` tests suite** requires specifying a GitHub access token in **.env file**.
3 years ago
```
gist_token = <token> // token should have permission to create a gist
```
3 years ago
### Using 'select_test' for locally running specific tests
3 years ago
There is a script to allow selecting the browser and a specific test to run:
3 years ago
```
3 years ago
yarn run select_test
3 years ago
```
3 years ago
You need to have
3 years ago
- selenium running
3 years ago
- the IDE running
3 years ago
- optionally have remixd or ganache running
3 years ago
### Splitting tests with groups
3 years ago
Groups can be used to group tests in a test file together. The advantage is you can avoid running long test files when you want to focus on a specific set of tests within a test file.x
These groups only apply to the test file, not across all test files. So for example group1 in the ballot is not related to a group1 in another test file.
Running a group only runs the tests marked as belonging to the group + all the tests in the test file that do not have a group tag. This way you can have tests that run for all groups, for example, to perform common actions.
3 years ago
There is no need to number the groups in a certain order. The number of the group is arbitrary.
3 years ago
A test can have multiple group tags, this means that this test will run in different groups.
3 years ago
You should write your tests so they can be executed in groups and not depend on other groups.
3 years ago
To do this you need to:
- Add a group to tag to a test, they are formatted as #group followed by a number: so it becomes #group1, #group220, #group4. Any number will do. You don't have to do it in a specific order.
3 years ago
```
'Should generate test file #group1': function (browser: NightwatchBrowser) {
browser.waitForElementPresent('*[data-id="verticalIconsKindfilePanel"]')
```
2 years ago
- add '@disabled': true to the test file you want to split:
```
3 years ago
module.exports = {
'@disabled': true,
before: function (browser: NightwatchBrowser, done: VoidFunction) {
init(browser, done) // , 'http://localhost:8080', false)
},
```
- change package JSON to locally run all group tests:
3 years ago
```
3 years ago
"nightwatch_local_debugger": "yarn run build:e2e && nightwatch --config dist/apps/remix-ide-e2e/nightwatch.js dist/apps/remix-ide-e2e/src/tests/debugger_*.spec.js --env=chrome",
3 years ago
```
- run the build script to build the test files if you want to run the locally
```
3 years ago
yarn run build:e2e
3 years ago
```
### Locally testing group tests
You can tag any test with a group name, for example, #group10 and easily run the test locally.
3 years ago
- make sure you have nx installed globally
- group tests are run like any other test, just specify the correct group number
#### method 1
This script will give you an options menu, just select the test you want
3 years ago
```
3 years ago
yarn run select_test
3 years ago
```
#### method 2
```
3 years ago
yarn run group_test --test=debugger --group=10 --env=chromeDesktop
3 years ago
```
- specify chromeDesktop to see the browser action, use 'chrome' to run it headless
### Run the same (flaky) test across all instances in CircleCI
In CircleCI all tests are divided across instances to run in parallel.
3 years ago
You can also run 1 or more tests simultaneously across all instances.
This way the pipeline can easily be restarted to check if a test is flaky.
For example:
```
3 years ago
'Static Analysis run with remixd #group3 #flaky': function (browser) {
```
Now, the group3 of this test will be executed in firefox and chrome 80 times.
3 years ago
If you mark more groups in other tests they will also be executed.
**CONFIGURATION**
It's important to set a parameter in the .circleci/config.yml, set it to false then the normal tests will run.
Set it to true to run only tests marked with flaky.
```
parameters:
run_flaky_tests:
type: boolean
default: true
```
## Important Links
- Official documentation: https://remix-ide.readthedocs.io/en/latest/
- Curated list of Remix resources, tutorials etc.: https://github.com/ethereum/awesome-remix
- Medium: https://medium.com/remix-ide
- Twitter: https://twitter.com/ethereumremix