Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Starts logging #34

Open
wants to merge 4 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,8 @@ checksums of files in the latest version, while the command in (4)
behavior. For example, to update the checksums while checking the
diff, run `mvn starts:diff -DupdateDiffChecksums=true`.

[Logging and Artifact Storage Docs](./STARTS-LOGGING.md)

## Papers on STARTS

Below is a list of research papers that describe some aspects of
Expand Down
94 changes: 94 additions & 0 deletions STARTS-LOGGING.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@

# Logging

## Intro

Logging in STARTS is a customized (read: simpler) version of [java.util.logging (JUL)](https://docs.oracle.com/javase/8/docs/api/java/util/logging/package-summary.html).

The code for logging is located in starts-core/src/main/java/edu/illinois/starts/util/Logger.java
owolabileg marked this conversation as resolved.
Show resolved Hide resolved


For any piece of starts that you'd like to add logging to, begin by adding two import statements at the top:

- ``import edu.illinois.starts.util.Logger;``
- ``import java.util.logging.Level;``

_note: you may need to make minor changes to the positioning of these two import statements to ensure checkstyle does not break. Place ``edu.illinois.starts.util.Logger`` directly underneath the other imports with the same package name, and do the same with ``java.util.logging.Level``. Additionally, ensure you have a newline separating different package names_
owolabileg marked this conversation as resolved.
Show resolved Hide resolved


Next, instantiate your Logger as a class variable:
- ``protected static final Logger logger = Logger.getGlobal();``

## Levels
There are 7 logging levels (excluding OFF and ALL), just like JUL:
- SEVERE (highest value)
- WARNING
- __INFO (default)__
- CONFIG
- FINE
- FINER
- FINEST (lowest value)

To set the logging level of your log, use the

``setLoggingLevel(Level level)``

method.
i.e.,

``logger.setLoggingLevel(Level.CONFIG);``

To check the logging level, use the ``getLoggingLevel()`` method, which will return an object of type [Level](https://docs.oracle.com/javase/8/docs/api/java/util/logging/Level.html).
i.e.,

``Level currentLevel = logger.getLoggingLevel();``

## Writing messages
There are two methods you can use to log that differ only in the number of arguments you pass in.

###### ``public void log(Level lev, String msg, Throwable thr)``
should be used when you want to have a custom message AND an exception message


###### ``public void log(Level lev, String msg)``
should be used when you only want to have a custom message

i.e.,

``logger.log(Level.SEVERE, "houston we have a problem");``

In both cases above, the provided message will only be logged if the specified logging Level is equal to or higher in severity than the Level the logger is set to.
For example, if ``logger.setLoggingLevel(Level.SEVERE);``, then only ``logger.log()`` messages with Level.SEVERE will be spit out.
Similarly, if ``logger.setLoggingLevel(Level.CONFIG);``, then ``logger.log()`` with Level.INFO will be output, but not Level.FINER.

## Where will messages be output?
Standard Output (System.out)

## Artifact storage
The logging granularities serve a dual purpose - both to control which log messages in code are sent to standard output, AND to control which artifacts are stored between runs.

The default __Level.INFO__ will store:
- _dependency file/checksum (.starts/deps.zlc)_

__Level.FINER__ will store:
- _dependency file/checksum (.starts/deps.zlc)_
- _list of all tests_
- _list of impacted tests_

__Level.FINEST__ will store:
- _dependency file/checksum (.starts/deps.zlc)_
- _list of all tests_
- _list of impacted tests_
- _list of non-impacted tests_
- _list of dependencies computed by jdeps_
- _classpath that STARTS used_
- _yasgl graph that STARTS constructed_
- _set of changed types_

To set the log level at runtime, call starts like this:

``mvn starts:starts -DstartsLogging=<Level>``

i.e.,

``mvn starts:starts -DstartsLogging=FINEST``