Logging

Logging dependency for Appulse Java projects

License

License

Categories

Categories

Java Languages Logging Application Layer Libs
GroupId

GroupId

io.appulse
ArtifactId

ArtifactId

logging-java
Last Version

Last Version

1.1.3
Release Date

Release Date

Type

Type

jar
Description

Description

Logging
Logging dependency for Appulse Java projects
Project URL

Project URL

https://github.com/appulse-projects/logging-java
Project Organization

Project Organization

Appulse
Source Code Management

Source Code Management

https://github.com/appulse-projects/logging-java

Download logging-java

How to add to project

<!-- https://jarcasting.com/artifacts/io.appulse/logging-java/ -->
<dependency>
    <groupId>io.appulse</groupId>
    <artifactId>logging-java</artifactId>
    <version>1.1.3</version>
</dependency>
// https://jarcasting.com/artifacts/io.appulse/logging-java/
implementation 'io.appulse:logging-java:1.1.3'
// https://jarcasting.com/artifacts/io.appulse/logging-java/
implementation ("io.appulse:logging-java:1.1.3")
'io.appulse:logging-java:jar:1.1.3'
<dependency org="io.appulse" name="logging-java" rev="1.1.3">
  <artifact name="logging-java" type="jar" />
</dependency>
@Grapes(
@Grab(group='io.appulse', module='logging-java', version='1.1.3')
)
libraryDependencies += "io.appulse" % "logging-java" % "1.1.3"
[io.appulse/logging-java "1.1.3"]

Dependencies

compile (1)

Group / Artifact Type Version
ch.qos.logback : logback-classic jar 1.2.3

provided (4)

Group / Artifact Type Version
org.projectlombok : lombok jar 1.18.12
net.jcip : jcip-annotations jar 1.0
com.github.spotbugs : spotbugs-annotations jar 4.0.0
com.google.code.findbugs : jsr305 jar 3.0.2

test (5)

Group / Artifact Type Version
org.junit.jupiter : junit-jupiter-engine jar 5.6.0
org.junit.jupiter : junit-jupiter-params jar 5.6.0
org.assertj : assertj-core jar 3.15.0
org.mockito : mockito-core jar 3.3.0
org.mockito : mockito-junit-jupiter jar 3.3.0

Project Modules

There are no modules declared in this project.

Overview

build_status maven_central License

Common logging project for Appulse project. It contains all required dependencies as well as colorizing configurations for logging output.

Usage

Just add dependency to your project.

Maven:

<dependencies>
    ...
    <dependency>
        <groupId>io.appulse</groupId>
        <artifactId>logging-java</artifactId>
        <version>1.1.3</version>
    </dependency>
    ...
</dependencies>

Gradle:

compile 'io.appulse:logging-java:1.1.3'

And use it as usual:

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class SomeClass {

  Logger log = LoggerFactory.getLogger(SomeClass.class);

  public void doSomeLog () {
    log.info("info message");
    log.warn("warn message");
    log.error("error message");
  }
}

or, if you use a Lombok Project:

import lombok.extern.slf4j.Slf4j;

@Slf4j
public class SomeClass {

  public void doSomeLog () {
    log.info("info message");
    log.warn("warn message");
    log.error("error message");
  }
}

With default configuration (no logback.xml in classpath at all) it looks like:

override example

You also could to override default logback's configuration, like an example below.

resources/logback.xml:

<?xml version="1.0" encoding="UTF-8"?>

<configuration>
  <property
    name="CONSOLE_LOG_PATTERN"
    value="${CONSOLE_LOG_PATTERN:-%clr(${LOG_LEVEL_PATTERN:-%5p}) %clr([%25.25thread]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}"
  />

  <include resource="io/appulse/logging/logback/base.xml"/>
</configuration>

And output will be like:

override example

Development

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Prerequisites

For building the project you need only a Java compiler.

IMPORTANT: the project requires Java version starting from 8

And, of course, you need to clone the project from GitHub:

$> git clone https://github.com/appulse-projects/logging-java
$> cd logging-java

Building

For building routine automation, I am using maven.

To build the project, do the following:

$> mvn clean package
...
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 18.447 s
[INFO] Finished at: 2018-01-23T18:36:20+03:00
[INFO] Final Memory: 52M/175M
[INFO] ------------------------------------------------------------------------

Running the tests

To run the project's test, do the following:

$> mvn clean test
...
[INFO] -------------------------------------------------------
[INFO]  T E S T S
[INFO] -------------------------------------------------------
...
[INFO]
[INFO] Results:
[INFO]
[INFO] Tests run: 20, Failures: 0, Errors: 0, Skipped: 0
[INFO]
...

Also, if you do package or install goals, the tests launch automatically.

Deploy

To deploy the project in Maven Central, use the following command:

$> ./mvnw \
    -DskipTests \
    -Dmaven.test.skip=true \
    -Dfindbugs.skip=true \
    -Dpmd.skip=true \
    -Dcheckstyle.skip \
    -Dmaven.javadoc.skip=false \
    --settings .settings.xml \
    deploy -B

It maybe usefull to import gpg's secret keys and ownertrust from somewhere:

$> echo "${GPG_SECRET_KEYS}" | base64 --decode | "${GPG_EXECUTABLE}" --batch --passphrase "${GPG_PASSPHRASE}" --import
...
$> echo "${GPG_OWNERTRUST}" | base64 --decode | "${GPG_EXECUTABLE}" --batch --passphrase "${GPG_PASSPHRASE}" --import-ownertrust
...

Built With

  • Java - is a systems and applications programming language

  • Lombok - is a java library that spicing up your java

  • Junit - is a simple framework to write repeatable tests

  • AssertJ - AssertJ provides a rich set of assertions, truly helpful error messages, improves test code readability

  • Maven - is a software project management and comprehension tool

Changelog

To see what has changed in recent versions of the project, see the changelog file.

Contributing

Please read contributing file for details on my code of conduct, and the process for submitting pull requests to me.

Versioning

We use SemVer for versioning. For the versions available, see the tags on this repository.

Authors

License

This project is licensed under the Apache License 2.0 License - see the license file for details

io.appulse

Appulse

Appulse aims to build correct concurrent and scalable applications based on JVM and BEAM VM.

Versions

Version
1.1.3
1.1.2
1.1.1
1.1.0
1.0.2
1.0.1
1.0.0