kibana/packages
Spencer 4e8ab56497
build immutable bundles for new platform plugins (#53976)
* build immutable bundles for new platform plugins

* only inspect workers if configured to do so

* [navigation] use an index.scss file

* add yarn.lock symlink

* set pluginScanDirs in test so fixtures stay consistent

* cleanup helpers a little

* fix type error

* support KBN_OPTIMIZER_MAX_WORKERS for limiting workers via env

* test support for KBN_OPTIMIZER_MAX_WORKERS

* expand the available memory for workers when only running one or two

* add docs about KBN_OPTIMIZER_MAX_WORKERS environment variable

* fix README link

* update kbn/pm dist

* implement bundle caching/reuse

* update kbn/pm dist

* don't check for cache if --no-cache is passed

* update renovate config

* standardize on index.scss, move console styles over

* add support for --no-cache to cli

* include worker config vars in optimizer version

* ignore concatenated modules

* update integration test

* add safari to browserslist to avoid user-agent warnings in dev

* update docs, clean up optimizer message/misc naming

* always handle initialized messages, don't ignore states that are attached to specific events

* reword caching docs, add environment var to disable caching

* tweak logging and don't use optimizer.useBundleCache as that's disabled in dev

* handle change notifications

* batch changes for 1 second

* rename CompilerState type to CompilerMsg

* getChanges() no longer needs to assign changes to dirs

* remove unused deps

* split up run_worker.ts and share cacheKey generation logic

* add a couple docs

* update tests and remove unused imports

* specify files when creating bundle cache key

* remove one more unused import

* match existing dev cli output more closely

* update kbn/pm dist

* set KBN_NP_PLUGINS_BUILT to avoid warning in CI

* avoid extending global window type

* add note to keep pluginScanDirs in sync

* pass browserslistEnv in workerConfig so it is used for cache key

* load commons.bundle.js in parallel too

* emit initialized+success states if all bundles are cached

* load bootstraps as quickly as possible

* skip flaky suite

* bump

* update jest snapshots

* remove hashing from cache key generation

* remove unnecessary non-null assertion

* improve docs and break up Optimizer#run()

* remove unused import

* refactor kbn/optimizer to break up observable logic, implement more helpful cache invalidation logic with logging

* fix tests

* add initializing phase

* avoid rxjs observable constructor

* remove unnecessary rxjs helper, add tests for bundle cache

* update consumers of optimizer

* update readme with new call style

* replace "new platform" with "kibana platform"

* fix a couple more renames

* add support for several plain-text file formats

* fix naming of OptimizerMsg => OptimizerUpdate, use "store" naming too

* one more OptimizerMsg update

* ensure bundles are not cached when cache config is false

* test for initializing states and bundle cache events

* remove unnecessary timeout change

* Remove unnecessary helpers

* Add tests for BundleCache class

* Add tests for Bundle class

* test summarizeEvent$

* missing paths are no longer listed in mtimes map

* add tests for optimizer/cache_keys

* Add some extra docs

* Remove labeled loop

* add integration test for kbn-optimizer watcher components

* querystring-browser removed

* tweak logging a smidge, improve info and final message

* remove unused imports

* remove duplication of getModuleCount() method

* move type annotation that validates things

* clear up the build completion message

Co-authored-by: Elastic Machine <elasticmachine@users.noreply.github.com>
2020-02-12 19:42:42 -07:00
..
elastic-datemath Add lockfile symlinks (#55440) 2020-01-27 11:38:20 -05:00
eslint-config-kibana Update eslint related packages (#54107) 2020-01-07 19:08:36 +01:00
kbn-analytics [Telemetry] fix bug where uiStatsMetrics is not getting report… (#54045) 2020-01-06 23:58:55 +02:00
kbn-babel-code-parser Add lockfile symlinks (#55440) 2020-01-27 11:38:20 -05:00
kbn-babel-preset chore(NA): use the same polyfill between the dev environment and the jest env (#57467) 2020-02-12 18:36:29 +00:00
kbn-config-schema kbn-config-schema: allow parsing of array and object types from string (#57189) 2020-02-11 11:19:02 +01:00
kbn-dev-utils build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-es Updating tree-kill to 1.2.2 (#55889) 2020-02-05 13:53:01 -08:00
kbn-eslint-import-resolver-kibana build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-eslint-plugin-eslint Add lockfile symlinks (#55440) 2020-01-27 11:38:20 -05:00
kbn-expect [kbn-expect] add optional error message (#48895) 2019-10-26 15:51:45 +02:00
kbn-i18n Add lockfile symlinks (#55440) 2020-01-27 11:38:20 -05:00
kbn-interpreter build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-optimizer build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-plugin-generator build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-plugin-helpers Upgrade node-sass to 4.13.1 (#56484) 2020-01-31 10:45:27 -05:00
kbn-pm build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-spec-to-console Add lockfile symlinks (#55440) 2020-01-27 11:38:20 -05:00
kbn-storybook build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-test build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-test-subj-selector Update eslint related packages (#48513) 2019-10-21 16:32:31 -07:00
kbn-ui-framework build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-ui-shared-deps build immutable bundles for new platform plugins (#53976) 2020-02-12 19:42:42 -07:00
kbn-utility-types Expressions refactor (#54342) 2020-02-11 19:47:36 +01:00
README.md [test] remove x-pack mocha configuration (#42979) 2019-08-15 12:21:42 -05:00

Kibana-related packages

This folder contains packages that are intended for use in Kibana and Kibana plugins.

tl;dr:

  • Don't publish to npm registry
  • Always use the @kbn namespace
  • Always set "private": true in package.json

Using these packages

We no longer publish these packages to the npm registry. Now, instead of specifying a version when including these packages, we rely on yarn workspaces, which sets up a symlink to the package.

For example if you want to use the @kbn/i18n package in Kibana itself, you can specify the dependency like this:

"@kbn/i18n": "1.0.0"

However, if you want to use this from a Kibana plugin, you need to use a link: dependency and account for the relative location of the Kibana repo, so it would instead be:

"@kbn/i18n": "link:../../kibana/packages/kbn-i18n"

How all of this works is described in more detail in the @kbn/pm docs.

Creating a new package

Create a new sub-folder. The name of the folder should mirror the name in the package's package.json. E.g. if the name is @kbn/i18n the folder name should be kbn-i18n.

All new packages should use the @kbn namespace, and should be marked with "private": true.

Unit tests for a package

Currently there are two patterns used to test packages, one using Mocha and one using Jest. These patterns emerged out of convention and we'd like to make them more similar to each other in the near future.

1. Mocha

Today a package can follow the pattern of having a __tests__ directory in each source code directory of a package which contains the tests for that module. These are usually run by Mocha.

If a package's tests should be run with Mocha, you'll have to opt-in to run them by appending the package's test file pattern(s) to Kibana's src/dev/mocha/run_mocha_cli.js file. These will then be run by the unit test runner.

  • yarn test or yarn grunt test runs all unit tests.
  • node scripts/mocha runs all Mocha tests.

2. Jest

A package can also follow the pattern of having .test.js files as siblings of the source code files, and these run by Jest.

A package using the .test.js naming convention will have those tests automatically picked up by Jest and run by the unit test runner, currently mapped to the Kibana test script in the root package.json.

  • yarn test or yarn grunt test runs all unit tests.
  • node scripts/jest runs all Jest tests in Kibana.

Each package can also specify its own test script in the package's package.json, for cases where you'd prefer to run the tests from the local package directory.