Skip to content

Commit

Permalink
Merge pull request #3121 from kbase/develop
Browse files Browse the repository at this point in the history
Merge to main for 5.1.3 release
  • Loading branch information
briehl authored Oct 31, 2022
2 parents b82cec9 + eeb59d8 commit 9f1b0c0
Show file tree
Hide file tree
Showing 36 changed files with 79,575 additions and 1,038 deletions.
2 changes: 1 addition & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@
# Made available under the KBase Open Source License
#

FROM ghcr.io/kbase/narrative-base-image:7.0.0
FROM ghcr.io/kbase/narrative-base-image:7.1.0

# These ARGs values are passed in via the docker build command
ARG BUILD_DATE
Expand Down
46 changes: 45 additions & 1 deletion RELEASE_NOTES.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,51 @@

The Narrative Interface allows users to craft KBase Narratives using a combination of GUI-based commands, Python and R scripts, and graphical output elements.

This is built on the Jupyter Notebook v6.0.2 (more notes will follow).
This is built on the Jupyter Notebook v6.4.12 and IPython 8.5.0 (more notes will follow).

## Version 5.1.3

- PTV-1620 - fix problem with Expression Pairwise Correlation creating or displaying large heatmaps and freezing or crashing browser
- PTV-1514 - sanitized HTML being used for app input tooltips

Dependency Changes
- Python dependency updates
- black >=20.8b1 -> 22.8.0
- coverage 6.2 -> 6.4.4
- cryptography 37.0.4 -> 38.0.1
- flake8 3.8.4 -> 5.0.4
- jinja2 3.0.3 -> 3.1.2
- jupyter-console 6.4.3 -> 6.4.4
- pygments 2.12.0 -> 2.13.0
- requests 2.27.1 -> 2.28.1
- Javascript dependency updates
- @wdio/cli 7.19.6 -> 7.25.0
- @wdio/local-runner 7.19.5 -> 7.25.0
- @wdio/spec-reporter 7.19.5 -> 7.25.0
- bootstrap 3.3.7 -> 3.4.1
- bootstrap-slider 10.6.2 -> 11.0.2
- chrome-launcher 0.14.2 -> 0.15.1
- chromedriver ^101.0.0 -> ^105.0.0
- cssnano 5.1.7 -> 5.1.13
- jasmine-core 4.1.0 -> 4.3.0
- jquery-ui 1.13.1 -> 1.13.2
- karma-jasmine-html-reporter 1.7.0 -> 2.0.0
- postcss-cli 9.1.0 -> 10.0.0
- prettier 2.4.1 -> 2.7.1
- puppeteer 13.7.0 -> 18.0.5
- require-css 0.1.8 -> 0.1.10
- sass 1.51.0 -> 1.55.0
- selenium-standalone 8.1.1 -> 8.2.0
- selenium-webdriver 4.1.2 -> 4.4.0
- terser 5.13.1 -> 5.15.0
- underscore 1.13.3 -> 1.13.6

Removed dependencies
**note** a number of these were removed from the narrative, but left in the narrative base image. The `requirements.txt` in this repo is intended for those packages required for the narrative to run. Any other packages, including scientific programming ones, useful for either KBase Apps or other manual use in Narrative code cells are included in the narrative base image (see [narrative-base-image](https://github.com/kbase/narrative-base-image) for more details). Also note that most of these are duplicated and included in that image - these are still necessary for narrative functionality when installed locally (i.e. not in a Docker image), so they're left in.
- plotly - not necessary for core narrative functionality, moved to narrative base image
- semantic_version -- removed, wasn't used effectively, and removed the need for it
- sklearn - still included, installed manually alongside clustergrammer in the install script, so the requirements.txt was removed
- sympy - not necessary for core narrative functionality, moved to narrative base image

### Version 5.1.2
- PTV-1823 - fixed problem where text input fields for apps were displaying incorrect data on reload
Expand Down
26 changes: 26 additions & 0 deletions docs/developer/local-docker.md
Original file line number Diff line number Diff line change
Expand Up @@ -131,3 +131,29 @@ make start build-image=f env=next local-narrative=t
## Done

You should now be able to navigate to https://ci.kbase.us, log in, and pull a Narrative from the Dashboard.

## Testing with a local container

Testing instructions assume that all JS and Python dependencies are installed locally, and that Narrative is built on the host for local usage.

This, however, is not necessary with the container, although it is necessary for now to install JS dependencies because tooling relies up it. Of course,
it would be possible to run any node-based tool via a simple node container, but that is for another day.

- Get the narrative running in one terminal window:
- `make dev-image`
- `ENV=ci make run-dev-image`
- In another terminal window:
- `NARRATIVE_SERVER_URL=http://localhost:8888 npm run test_local`

Please note the volume mounts in `scripts/local-def-run.sh`. Not all directories in kbase-extension/static local narrative repo are mounted, due to
the fact that ext_components is installed.

To explain the `ext_` directories briefly.

- `ext_modules` is where all node modules should be placed; that is what it was originally designed for and a very few npm dependencies are placed there;
it does not exist until the narrative is built.
- `ext_components` is where `node_modules` is copied to, for those bower components which were migrated to npm modules; it also does not exist until the
narrative is built.
- `ext_packages` is where old dependencies which cannot be brought into the codebase as normal npm dependencies reside; it essentially never changes as
it freezes certain dependencies that could not be brought in as bower dependencies when the narrative was converted from manually installed
dependencies to bower.
7 changes: 2 additions & 5 deletions kbase-extension/static/kbase/js/common/html.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
define(['uuid'], (Uuid) => {
define(['uuid', 'util/string'], (Uuid, StringUtil) => {
'use strict';

const TAGS = {};
Expand Down Expand Up @@ -102,10 +102,7 @@ define(['uuid'], (Uuid) => {
})();
switch (typeof attribValue) {
case 'string': {
const escapedValue = attribValue.replace(
new RegExp('\\' + quoteChar, 'g'),
'\\' + quoteChar
);
const escapedValue = StringUtil.escape(attribValue);
return `${attribName}=${quoteChar}${escapedValue}${quoteChar}`;
}
case 'boolean':
Expand Down
Loading

0 comments on commit 9f1b0c0

Please sign in to comment.