Please report bugs and feature requests to the GitHub issue tracker.
- Use the oVirt Users forum / mailing list for general discussion or help.
- Use the oVirt Devel forum / mailing list development discussion.
- Have the oVirt engine running at https://[ENGINE_URL]
- example: https://engine.local/ovirt-engine
- Have packages
autoconf
,automake
andlibtool
installed - Have
yarn
installed - Not strictly required but suggested, use the
ovirt-engine-nodejs-modules
package git clone
the repository
Install ovirt-engine-nodejs-modules
from the ovirt/tested
yum repo for your platform
to use the same packages that will be used by CI to build the app.
REPO=fc30 # or the appropriate release and version for you
dnf config-manager --add-repo http://resources.ovirt.org/repos/ovirt/tested/master/rpm/$REPO
dnf install ovirt-engine-nodejs-modules
To set PATH and use yarn, the yarn offline cache provided by ovirt-engine-nodejs-modules
and use these packages for development or building use:
source /usr/share/ovirt-engine-nodejs-modules/setup-env.sh
If you want to stop using yarn
offline, yarn
will need to be reconfigured to remove
the offline mirror added by setup-env.sh
:
yarn config delete yarn-offline-mirror
NOTE: During development it is not necessary to limit your environment to the offline
yarn repo provided by ovirt-engine-nodejs-modules
. However, it is recommended to run a
full build to verify no dependency errors will be introduced by your change. oVirt
STDCI will fail if ovirt-engine-nodejs-modules
needs to be updated with changes made
to package.json
or yarn.lock
in a new pull request.
A primary goal of VM Portal is a quick development cycle (change-build-deploy-check). The project uses webpack-dev-server to accomplish this. To start the server:
ENGINE_URL=https://my.ovirt.instance/ovirt-engine/ yarn start
When asked, provide a valid user name (in the form of user@profile
) and password so
the application can start in the context of a logged in user.
You can group environment variables using .env.envname
files. For example, for environment foo
create a file .env.foo
in the root of the project cotaining all related variables.
The file should follow dotenv convention.
Then start the server with:
ENGINE_ENV=foo yarn start
User name and password can also be provided via shell variables:
ENGINE_USER=user@profile
ENGINE_PASSWORD=password
ENGINE_DOMAIN=domain
When the dev server is started, it will attempt to open a new browser window/tab on
your system default browser to the app's running URL. This behavior can be modified
by specifying the BROWSER
environment variable. Possible values are:
BROWSER=none # disable the feature
BROWSER=google-chrome # open a new tab in chrome on Linux
BROWSER='google chrome' # open a new tab in chrome on MacOS
BROWSER=chrome # open a new tab in chrome on Windows
BROWSER=firefox # open a new tab in firefox on Linux
To test an alternative branding, the dev server may be started with the BRANDING
environment variable. This variable allows specifying a location where alternative
branding file are located. For example, if there is an alternative branding located
at $HOME/new-branding
, start the dev server like this:
ENGINE_URL=https://my.ovirt.instance/ovirt-engine \
BRANDING=$HOME/new-branding \
yarn start
Under normal circumstances, the token generated when the dev server starts will
expire after non-use. That interval is determined by setting on the ovirt-engine. If
you do not want the dev server session to expire when the UI does the non-activity
logout, the KEEP_ALIVE
environment variable may be used. This will keep the dev
server's session alive by pining the rest api at the specified minute interval. For
example, running the dev server like this will have it ping the rest api every 20 minutes,
keeping the session alive even if the UI is logged out or closed:
ENGINE_URL=https://my.ovirt.instance/ovirt-engine \
KEEP_ALIVE=20 \
yarn start
You can build the static assets from source by:
# skip if you don't want to use offline mode
source /usr/share/ovirt-engine-nodejs-modules/setup-env.sh
./autogen.sh
make
This allows you to run VM Portal deployed directly in an ovirt-engine development installation.
# skip if you don't want to use offline mode
source /usr/share/ovirt-engine-nodejs-modules/setup-env.sh
./autogen.sh --prefix=/usr --datarootdir=/share
make all install-data-local DESTDIR=<path_to_engine_development_prefix>
There are at least 4 ways to build the RPM for the project:
- Manually with
make rpm
:
source /usr/share/ovirt-engine-nodejs-modules/setup-env.sh
./autogen.sh --prefix=/usr --datarootdir=/share
make rpm
-
Use mock_runner to run CI build artifacts locally (this method is cleanest since it runs in a chroot).
-
Each pull request push will automatically have RPMs built (the check-patch, check-merged, and build-artifact stages all use the same script:
automation/build.sh
) by oVirt infra STDCI. The most recent build on the master branch is available on STDCI last successful build artifacts. -
Post the comment "
ci build please
" to the GitHub Pull Request for an on-demand CI build artifacts build. Reference manual functionality of the oVirt CI system.
yum install ovirt-web-ui
Installs the app to /usr/share/ovirt-web-ui
. A new ovirt-web-ui.war is added to the existing ovirt-engine.ear.
You can access the application at: https://[ENGINE_URL]/ovirt-engine/web-ui
The latest ovirt-web-ui RPM can be found in the Copr build system.
A pair of extensions are recommended to simplify debugging of the application:
- based on React, Patternfly, Redux, Redux-Saga
- based on ejected create-react-app
- fast UI responses and start-up
- improved usability and look & feel
- easy customization for your own oVirt UI implementation
- can be deployed as a self-standing lightweight app (docker image)
- integration with other components like Cockpit or ManageIQ
- code reusability, extensibility, and simplicity
- simplified maintenance and ongoing development
For more info, see doc/goals.md
- Marek Libra ([email protected])
- Bohdan Iakymets ([email protected])
- Jakub Niedermertl ([email protected])
- Scott Dickerson ([email protected])
- Greg Sheremeta ([email protected])