Commit Graph

491 Commits

Author SHA1 Message Date
Michael Bradley, Jr f10e0258cb build: introduce a `prepare` script in embark's package.json
**TL;DR**

These changes affect workflow with yarn. To prevent embark's `prepare` script
from running undesirably:

- If node_modules is in place and you're reinstalling after switching branches:

```
yarn run install_all
```

- If node_modules is missing (fresh clone or deleted):

```
EMBARK_NO_PREPARE=t yarn install && yarn run install_all
```

It's not recommended to set `EMBARK_NO_PREPARE` in your environment (e.g. in
`.bashrc`) since that would interfere with embark's `release` script if/when
you run it.

-----------------

**1.** Specify embark's build-related steps in the `prepare` script of
  package.json.

When embark is installed directly from GitHub the `prepare` script results in a
"pre install" phase (handled automatically by npm/yarn) that fetches
devDependencies, builds embark (including embark-ui), packs a tarball with the
same steps (minus testing and tree-checking) as would happen during an embark
release, and finally does a production install from that tarball.

Important point: installs from GitHub must be performed with yarn; they're no
longer possible with npm since during the "pre install" phase npm will honor
embark's `.npmrc` and `"engines"` settings.

The following will work correctly after this commit is merged:

```
yarn [global] add git+https://github.com/embark-framework/embark.git
```

Use of "hosted git" shortcuts (e.g. `embark-framework/embark#bracnh`) won't
work correctly because yarn doesn't fully support them. See:
https://github.com/yarnpkg/yarn/issues/5235.

It's important to use `git+https` urls. Following a succesful install with
`git+https` it is possible to use a "hosted git" shortcut or `https` url, but
that's owing to a subtle and unreliable interaction between yarn's cache and
yarn's logic for installing from a url/shortcut.

**2.** Adjust the npm configs (`.npmrc`) for embark/-ui so that `yarn run [cmd]
  [--opt]` can be used in place of `npm run [cmd] -- [--opt]`.

Either way is okay for running scripts, they're equivalent, but note the
requirement to use `--` before specifying command options with `npm run`.

**3.** Introduce yarn configs (`.yarnrc`) for embark/-ui and include the
  `check-files` directive.

H/t to @alaibe for the recommendation.

**4.** Ignore embark's `dist/typings` and `scripts` directories when packing a
  tarball.

**5.** Refactor embark/-ui's npm-scripts in relation to the `prepare` script,
  and make other small improvements.

Notably, if the environment variable `EMBARK_NO_PREPARE` is truthy (from JS
perspective) then embark's `prepare` script will exit early. This prevents
`install_all` and `prepare` from getting stuck in a loop (`install:core` uses
cross-env to set `EMBARK_NO_PREPARE`) and provides a mechanism for users to
skip the `prepare` script when doing a fresh install:

```
EMBARK_NO_PREPARE=t yarn install
```

**6.** Give `.js` extensions to node scripts in embark's `scripts/`, remove the
  shebang lines, and have npm-scripts explicitly invoke them with node.

This arrangement works for all platforms: Linux, macOS, and Windows.

**7.** Adjust travis and appveyor configs.

Since at present there aren't any tests or other CI steps that make use of
embark-ui's production build, set `EMBARK_NO_PREPARE` in the CI environments
and invoke `build:node` directly.

Check the working tree after `yarn install` for embark/-ui. This detects
situations where changes should have been committed to `yarn.lock` but were
not. Check the working tree again at the end to detect situations where ignore
files should have been adjusted but were not. Both checks could also detect
other surprising behavior that needs to be investigated. Any time the working
tree is not clean (there are untracked files or changes) CI will fail.

Drop CI runs for node 8.11.3 because that version ships with an older npm that
results in unstaged changes to the test apps' `package-lock.json` files,
causing the working tree check to fail at the end of the CI run. A simple
workaround isn't apparent, but the matter can be revisited.

**8.** Refactor embark's `release` script in light of the `prepare` script.

Notably, do the push step only after `npm publish` completes successfully. This
allows embark's `prepare` and `prepublishOnly` scripts to detect problems
before a commit and tag are pushed to GitHub, avoiding a need to rebase/revert
the remote release branch; the local branch will still need to have a commit
dropped and tag deleted before rerunning the `release` script.

Prompt the user if the `release` script is not being run in `--dry-run` mode.

Provide additional visual indicators of `--dry-run` mode.

Force the user to supply `--repo-branch [branch]` if the intention is to
release from a branch other than `master`.
2018-12-03 16:24:10 -06:00
Anthony Laibe 160015311e fix(ui): click on debug button start the debugger
Remove fake line
2018-11-28 09:21:45 +00:00
Anthony Laibe 7728c542e9 fix: open/close aside container 2018-11-26 15:38:35 +00:00
Jonathan Rainville d09d410021 refactor(ENS): adds a whitelist for ens
Enables only the use of domains in that white list
2018-11-23 16:32:57 -05:00
Michael Bradley, Jr 53191447f5 build: use yarn for reproducible builds and CI
yarn.lock files are generated for embark and embark-ui, and their package.json
files and other npm related files are updated to support and require using yarn
for development of embark itself and for embark's CI.
2018-11-20 09:25:42 -06:00
Michael Bradley, Jr 9cd50c2031 build: remove and disable npm lock files, rely on pinned dev/deps
Buggy behavior related to npm lock files makes the goal of reproducible builds
and hassle-free automated releases nearly impossible to achieve at
present. With npm's lock files disabled we rely on pinned dependencies (exact
versions only in the package.json files of embark and embark-ui) for a
hopefully good result. This is an experiment while the project is in an alpha
release phase, and if problems are experienced we can return to using
npm-shrinkwrap.json / package-lock.json, or we can investigate a transition to
the yarn package manager, for ourselves and possibly for our users too.
2018-11-20 09:25:42 -06:00
Anthony Laibe 10caddd872 fix(ui): white screen on text editor
Only happens on Firefox
2018-11-20 13:31:50 +00:00
Anthony Laibe 66e431cf13 fix(ui): switch aside 2018-11-20 09:21:03 +00:00
Anthony Laibe 192e6e112a chore(embark-ui): upgrade embark-ui to latest and greatest CRA 2018-11-13 10:55:35 +00:00
Anthony Laibe f82d3de1b0 feat: add CRUD to file explorer 2018-11-13 09:13:23 +00:00
Michael Bradley, Jr 23f19a0df5 fix: runtime environment needs to support locally installed embark
Reintroduce NODE_PATH so that DApps with embark locally installed can properly
resolve modules supplied by embark. Refactor process.env related settings into
src/lib/core/env.js
2018-11-12 11:03:48 -06:00
Michael Bradley, Jr 69dd8c5b89 build(packaging): reorg sources for transpilation with Babel
Allow for embark sources to be authored in TypeScript and/or JavaScript, and to
make use of upcoming features of the JS language. Sources in the src/ directory
are transpiled into the dist/ directory, and npm-scripts are provided to
support and automate various aspect of the build process. Source map support is
enabled at runtime, i.e. when invoking the embark cli and running embark's test
suite.
2018-11-11 15:08:55 -06:00
Anthony Laibe 184e1e277a feat: add debug button to transaction and contract log 2018-11-09 09:29:58 +00:00
Iuri Matias 087a2e8c6b
Merge branch 'master' into feature/deployment-strategy 2018-11-08 16:35:04 -05:00
Iuri Matias 70b26176db
Merge pull request #1036 from embark-framework/features/eth-search
Add searching ENS names in cockpit search bar
2018-11-08 16:22:03 -05:00
Iuri Matias c3ae7d608f
Merge pull request #1035 from embark-framework/chore/disable-autocomplete-login
Disable autocomplete in Login component and fix indentation
2018-11-08 16:21:30 -05:00
Jonathan Rainville 1030607813 feat(cockpit): make editor resizable 2018-11-08 15:17:41 -05:00
Jonathan Rainville a714e078c4 fix(cockpit): fix aside not opening correctly and typos 2018-11-08 13:57:48 -05:00
Jonathan Rainville 3ddcd1f825 fix(cockpit): disable autocomplete in Login component 2018-11-08 12:06:57 -05:00
Jonathan Rainville dca52d0d4e feat(cockpit): add searching ENS names in search bar 2018-11-08 12:04:27 -05:00
Iuri Matias 8a4b5d3d5d
Merge pull request #1034 from embark-framework/chore/remove-interfaces-deploy
Hide interfaces in contract deployment page
2018-11-08 10:21:42 -05:00
Pascal Precht 3c0e360540
refactor(cockpit/TextEditorToolbar): make toolbar tabs generation more generic 2018-11-07 13:35:22 +01:00
Anthony Laibe 0e7aad81aa chore: remove fiddle dead code 2018-11-07 11:35:36 +00:00
Jonathan Rainville 24e3da65b2 fix proptypes warnings and fix indexes 2018-11-06 15:55:57 -05:00
Jonathan Rainville 2f4625c143 hide interfaces in contract deployment page 2018-11-06 14:57:06 -05:00
Anthony Laibe 3ef7fd7411 Event filter typo 2018-11-01 14:11:51 +01:00
Anthony Laibe 436786bfe4 Add back event on file save sucess 2018-10-31 16:55:25 +01:00
Michael Bradley, Jr b5b581c6c0 bump embark-ui pkg lock 2018-10-31 11:01:34 +01:00
Eric Mastro 63847b7842
Merge pull request #1015 from embark-framework/bug_fix/gas-estimator
Add a warning when there is no blocks for the estimator
2018-10-31 10:37:26 +01:00
Jonathan Rainville dbe12c6fb9 add a warning if not enough blocks or no blocks 2018-10-31 10:26:24 +01:00
Eric Mastro 941e8175cb
Merge pull request #1014 from embark-framework/bug_fix/search-error
Fix search bar
2018-10-31 10:18:50 +01:00
Jonathan Rainville 4c1df9eaf5 restyle alert bar and move it to an scss import 2018-10-30 22:01:28 +01:00
emizzle f645119ea6 Fix console errors/warnings 2018-10-30 21:36:47 +01:00
Jonathan Rainville 5f53d6bf2e hide the serach Error when there is a success 2018-10-30 20:56:59 +01:00
Eric Mastro 8d33ac6cb4
Merge pull request #1011 from embark-framework/bugfix/deployment-interface
Do no show interface on injected web3
2018-10-30 20:55:52 +01:00
Eric Mastro 4e7ae9aa17
Merge pull request #1010 from embark-framework/fix_whisper
fix whisper in embark-ui
2018-10-30 20:55:20 +01:00
Anthony Laibe dc6294ad84 Do no show interface on injected web3 2018-10-30 20:51:23 +01:00
Iuri Matias 4ee0f38278
Merge pull request #1009 from embark-framework/features/icons-for-explorer
Add icons for the contract page
2018-10-30 20:46:23 +01:00
Iuri Matias 54dc34ef15
Merge pull request #1007 from embark-framework/fix/make-linter-happy
Make linter happy 2019
2018-10-30 20:45:44 +01:00
Michael Bradley, Jr 82e4253e34 fix whiper in embark-ui 2018-10-30 20:38:21 +01:00
Jonathan Rainville 0634a47cff change icons for the contract page 2018-10-30 19:42:08 +01:00
Andre Medeiros 57be7d38dd Make linter happy 2019 2018-10-30 18:42:54 +01:00
Anthony Laibe 1b2050907f bug: empty response 2018-10-30 18:07:02 +01:00
Iuri Matias 10ccb9489f
Merge pull request #1005 from embark-framework/feature/highlight-header
Highlight header tab
2018-10-30 17:44:08 +01:00
Iuri Matias 473b6fc0ee replace browser icon 2018-10-30 17:43:40 +01:00
Anthony Laibe 0671da2347 Highlight header tab 2018-10-30 17:41:12 +01:00
Iuri Matias 10fd5af9a6 add workaround for env issue in the tests 2018-10-29 16:36:27 +01:00
Jonathan Rainville c6902efb2f fix Transactions constant 2018-10-29 12:32:24 +01:00
Jonathan Rainville f1d113a431 put aside under when on a small screen 2018-10-29 12:29:43 +01:00
Jonathan Rainville e0ce61f112 resolve conflict with Logger name 2018-10-29 12:29:20 +01:00