Skip to content

Latest commit

 

History

History
194 lines (134 loc) · 8.02 KB

DEVELOPERS.md

File metadata and controls

194 lines (134 loc) · 8.02 KB

Build Status

VM Portal - Developer information

Bugs and Enhancements

Please report bugs and feature requests to the GitHub issue tracker.

Users Forum

Development setup

Prerequisites

  • Have the oVirt engine running at https://[ENGINE_URL]
  • Have packages autoconf, automake and libtool installed
  • Have yarn installed
  • Not strictly required but suggested, use the ovirt-engine-nodejs-modules package
  • git clone the repository

ovirt-engine packages

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.

Development mode

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.

.env.* files

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

Credentials

User name and password can also be provided via shell variables:

ENGINE_USER=user@profile
ENGINE_PASSWORD=password
ENGINE_DOMAIN=domain

Auto-Open browser

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

Alternative Branding

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

Keep-alive

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

Production Builds

Build static assets

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

Build and install to a local development ovirt-engine

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>

Build RPM

There are at least 4 ways to build the RPM for the project:

  1. Manually with make rpm:
source /usr/share/ovirt-engine-nodejs-modules/setup-env.sh
./autogen.sh --prefix=/usr --datarootdir=/share
make rpm
  1. Use mock_runner to run CI build artifacts locally (this method is cleanest since it runs in a chroot).

  2. 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.

  3. 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.

RPM Installation

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.

Browser Developer Tools

A pair of extensions are recommended to simplify debugging of the application:

Technical Details

  • based on React, Patternfly, Redux, Redux-Saga
  • based on ejected create-react-app

Goals

  • 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

Author(s)