Apache OpenWhisk runtime for Node.js JavaScript language functions. https://openwhisk.apache.org/
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Type Name Latest commit message Commit time
Failed to load latest commit information.
.github replace github refs openwhisk to apache (#2236) May 15, 2017
core use stretch instead of jessie for nodejs10 (#99) Nov 8, 2018
tests Add support for NodeJS10 (#98) Nov 7, 2018
.scalafmt.conf Add ASF license headers to all Scala .conf files. May 8, 2018
DISCLAIMER.txt Add the DISCLAIMER file for Apache incubator project (#56) Jun 12, 2018
README.md Add support for NodeJS10 (#98) Nov 7, 2018
build.gradle Last files to need ASF License headers. (#54) May 23, 2018
gradlew Bumping to gradle 4.1. (#2399) Aug 16, 2017
gradlew.bat Bump gradle version to 3.0 Sep 18, 2016


Apache OpenWhisk runtimes for nodejs

License Build Status

Give it a try today

To use as a docker action for Node.js 6

wsk action update myAction myAction.js --docker openwhisk/nodejs6action

To use as a docker action for Node.js 8

wsk action update myAction myAction.js --docker openwhisk/action-nodejs-v8

This works on any deployment of Apache OpenWhisk

To use on deployment that contains the rutime as a kind

To use as a kind action using Node.js 6

wsk action update myAction myAction.js --kind nodejs:6

To use as a kind action using Node.js 8

wsk action update myAction myAction.js --kind nodejs:8

Local development

For Node.js 6

./gradlew core:nodejs6Action:distDocker

This will produce the image whisk/nodejs6action

For Node.js 8

./gradlew core:nodejs8Action:distDocker

This will produce the image whisk/action-nodejs-v8

For Node.js 10

./gradlew core:nodejs10Action:distDocker

This will produce the image whisk/action-nodejs-v10

Build and Push image for Node.js 6

docker login
./gradlew core:nodejs6Action:distDocker -PdockerImagePrefix=$prefix-user -PdockerRegistry=docker.io

Build and Push image for Node.js 8

docker login
./gradlew core:nodejs8Action:distDocker -PdockerImagePrefix=$prefix-user -PdockerRegistry=docker.io

Then create the action using your image from dockerhub

wsk action update myAction myAction.js --docker $user_prefix/nodejs6action

The $user_prefix is usually your dockerhub user id.

Deploy OpenWhisk using ansible environment that contains the kind nodejs:6 and nodejs:8 Assuming you have OpenWhisk already deployed locally and OPENWHISK_HOME pointing to root directory of OpenWhisk core repository.

Set ROOTDIR to the root directory of this repository.

Redeploy OpenWhisk

cd $OPENWHISK_HOME/ansible
ANSIBLE_CMD="ansible-playbook -i ${ROOTDIR}/ansible/environments/local"
$ANSIBLE_CMD setup.yml
$ANSIBLE_CMD couchdb.yml
$ANSIBLE_CMD initdb.yml
$ANSIBLE_CMD wipe.yml
$ANSIBLE_CMD openwhisk.yml

Or you can use wskdev and create a soft link to the target ansible environment, for example:

ln -s ${ROOTDIR}/ansible/environments/local ${OPENWHISK_HOME}/ansible/environments/local-nodejs
wskdev fresh -t local-nodejs


Install dependencies from the root directory on $OPENWHISK_HOME repository

./gradlew install

Using gradle for the ActionContainer tests you need to use a proxy if running on Mac, if Linux then don't use proxy options You can pass the flags -Dhttp.proxyHost=localhost -Dhttp.proxyPort=3128 directly in gradle command. Or save in your $HOME/.gradle/gradle.properties


Using gradle to run all tests

./gradlew :tests:test

Using gradle to run some tests

./gradlew :tests:test --tests *ActionContainerTests*

Using IntelliJ:

  • Import project as gradle project.
  • Make sure working directory is root of the project/repo
  • Add the following Java VM properties in ScalaTests Run Configuration, easiest is to change the Defaults for all ScalaTests to use this VM properties


Apache OpenWhisk Runtime Node.js is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by the Apache Incubator. Incubation is required of all newly accepted projects until a further review indicates that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. While incubation status is not necessarily a reflection of the completeness or stability of the code, it does indicate that the project has yet to be fully endorsed by the ASF.