Bug 574897 - Switch JobManager to nanoTime() and monotonic time

Usage of System.currentTimeMillis() in Jobs framework is problematic,
because System.currentTimeMillis() API depends on external time sources
and may go backwards and forwards at any time, contrary to our "human"
understanding of the "monotonic" time that can never go back. However,
code responsible for scheduling and joining on jobs depends on time
values delivered by that API and I assume may be confused if time goes
backwards.

Since Java 5, System.nanoTime() was added to allow better precision and
less system dependent time measurements. While still not strictly
monotonic, it is  less problematic as System.currentTimeMillis(),
because it is not depending on system time changes that could be made by
user or by synchronization of local time with NTP server.

This change switches JobManager and related code to use
System.nanoTime() and introduces JobManager.now() as a source for
monotonic non-negative time values independent on local time and
consistent between multiple threads.

Change-Id: I6e90b4c962318705062148c1929838885404ad26
Signed-off-by: Andrey Loskutov <loskutov@gmx.de>
Reviewed-on: https://git.eclipse.org/r/c/platform/eclipse.platform.runtime/+/183139
Tested-by: Platform Bot <platform-bot@eclipse.org>
10 files changed
tree: 7863a25ade9b08ed78fd4e76aacded61d427b971
  1. bundles/
  2. features/
  3. tests/
  4. .gitignore
  5. CONTRIBUTING
  6. CONTRIBUTING.md
  7. Jenkinsfile
  8. LICENSE
  9. NOTICE
  10. pom.xml
  11. README.md
README.md

Contributing to Eclipse Platform runtime project

Thanks for your interest in this project.

Project description:

Platform runtime provides the background componentns for Eclipse based applications.

Website: https://projects.eclipse.org/projects/eclipse.platform

For more information, refer to the Platform UI wiki page.

How to contribute:

Contributions to Platform UI are most welcome. There are many ways to contribute, from entering high quality bug reports, to contributing code or documentation changes. For a complete guide, see the Platform UI - How to contribute wiki page page on the team wiki.

Test dependencies

Several test plug-ins have a dependency to the Mockito and Hamcrest library. Please install them from the Orbit Download page

Currently the following versions are required:

  • org.hamcrest;bundle-version=“1.3.0”,
  • org.mockito;bundle-version=“2.13”,

How to build on the command line

You need Maven 3.3.1 installed. After this you can run the build via the following command:

mvn clean verify -Pbuild-individual-bundles

Developer resources:

Information regarding source code management, builds, coding standards, and more.

Contributor License Agreement:

Before your contribution can be accepted by the project, you need to create and electronically sign the Eclipse Foundation Contributor License Agreement (CLA).

Search for bugs:

This project uses Bugzilla to track ongoing development and issues.

Create a new bug:

Be sure to search for existing bugs before you create another one. Remember that contributions are always welcome!

Contact:

Contact the project developers via the project's “dev” list.

License

Eclipse Public License (EPL) 2.0