This repository demonstrates working with GitHub and the services in its marketplace & ecosystem, such as Travis, CodeCoverage, VersionEye, and JitPack.
- Creating an account
- Creating a repository
- License badge
- Creating a .gitignore
- Cloning the repository
- Adding the pom.xml
- First code
- Adding a test
- Travis CI
- Codecov
- Codecov on pull requests
- Creating a release
- Jitpack
- VersionEye
- Final repository example
- Materials
Go to https://github.com/ and sign up. Pick the free plan and verify your email address.
Enter a repository name and initialize the repository with a README and the Apache License 2.0.
Go to https://gist.github.com/lukas-h/2a5d00690736b4c3a7ba and copy the markdown for your license, in this case Apache 2.0. Add it to your README.MD as you did with the other badge markdowns.
Create new file, name it ".gitignore", pick the Java template, and add your IDE's files to the file.
Copy the repository URL into your clipboard and clone the repository in your IDE.
Create a pom.xml in the root directory, and add JodaToJava8Converter.java in a package, and create a test in the test tree.
<?xml version="1.0"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<groupId>mafoe</groupId>
<artifactId>working-with-github</artifactId>
<version>1.0-SNAPSHOT</version>
<modelVersion>4.0.0</modelVersion>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.7.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>joda-time</groupId>
<artifactId>joda-time</artifactId>
<version>2.7</version>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
</dependency>
</dependencies>
</project>
package mafoe;
import org.joda.time.DateTime;
import java.time.ZoneId;
/**
* Converts Joda time objects to javax.time objects.
*
* @author EMAFOER
*/
public class JodaToJava8Converter {
public static java.time.ZonedDateTime convertTimestamp(DateTime jodaDateTime) {
String zoneId = jodaDateTime.getZone().getID();
return java.time.ZonedDateTime.of(
jodaDateTime.getYear(),
jodaDateTime.getMonthOfYear(),
jodaDateTime.getDayOfMonth(),
jodaDateTime.getHourOfDay(),
jodaDateTime.getMinuteOfHour(),
jodaDateTime.getSecondOfMinute(),
jodaDateTime.getMillisOfSecond() * 1000 * 1000,
ZoneId.of(zoneId));
}
}
package mafoe;
import org.joda.time.DateTime;
import org.junit.Test;
import java.time.ZonedDateTime;
import static org.junit.Assert.*;
/**
* @author EMAFOER
*/
public class JodaToJava8ConverterTest {
@Test
public void testConvertTimestamp() {
DateTime jodaTime = DateTime.parse("2010-06-30T01:20+02:00");
ZonedDateTime zonedDateTime = JodaToJava8Converter.convertTimestamp(jodaTime);
assertEquals("2010-06-30T01:20+02:00", zonedDateTime.toString());
}
}
From Travis CI's homepage:
Test and Deploy with Confidence
Easily sync your GitHub projects with Travis CI and you’ll be testing your code in minutes!
In the settings, add the Travis CI service to your repository:
Add a file named ".travis.yml" into the root directory:
language: java
jdk:
- oraclejdk8
Go to https://travis-ci.org/auth?redirectUri=https%3A%2F%2Ftravis-ci.org%2Fprofile and sign in with GitHub, then authorize travis-ci.
Switch the new repository to "on" on the page you're being redirected to. Click on "More Options" -> "Trigger Build" to trigger a build automatically, or push a change to GitHub to trigger an automatic build.
At the top of the travis build page, there is a badge. Click it and select "Markdown" code. Copy the markdown to clipboard...
... and add it to the README.MD:
The result should look like this:
From Codecov's GitHub marketplace page:
Codecov provides highly integrated tools to group, merge, archive and compare coverage reports.
Visit https://github.com/marketplace/codecov and set up a free trial for "Open Source". "Install for free".
Login and authorize Codecov. Add the new repository.
Edit your pom.xml to add the cobertura plugin into the build/plugins block:
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>cobertura-maven-plugin</artifactId>
<version>2.7</version>
<configuration>
<formats>
<format>html</format>
<format>xml</format>
</formats>
<check />
</configuration>
</plugin>
Edit the .travis.yml (Codecov easily integrates with Travis CI) to look like this:
language: java
jdk:
- oraclejdk8
script: "mvn cobertura:cobertura"
after_success:
- bash <(curl -s https://codecov.io/bash)
Note that we tell travis to call the cobertura plugin and the curl to send the coverage report to Codecov.
Your next travis build should start automatically after pushing your changes, and should send coverage information to Codecov.
Now you can go to https://codecov.io/, log in if necessary, go to Settings -> Badge -> Markdown, copy the markdown and add it to your README.MD. Now you should see a coverage percentage in GitHub like so:
Travis will build on creating a pull request, and that build will count as a check in the pull request. This also triggers Codecov, adding Codecov checks to the pull request. There is even a Codecov bot commenting on pull requests. We'll try this with a code change.
First, create a feature branch and add the following method to the JodaToJava8Converter class.
public static java.time.LocalDate convertLocalDate(LocalDate jodaLocalDate) {
return java.time.LocalDate.of(
jodaLocalDate.getYear(),
jodaLocalDate.getMonthOfYear(),
jodaLocalDate.getDayOfMonth());
}
Then push the new branch with this change to GitHub. On GitHub, create a pull request to merge the new branch into the master branch, and open the pull request. You will see some checks inside the pull request page, consisting of travis builds. As soon as travis has finished, Codecov checks are added to the pull request. In our case, the travis checks will suceed, because our project still builds. But the Codecov checks will fail, because the new code we committed is not covered by tests, and will decrease our code coverage substantially:
The Codecov bot should add an unflattering, very visual comment as well:
We can and should fix the problem by adding a test such as this to JodaToJava8ConverterTest.java:
@Test
public void testConvertLocalDate() {
LocalDate jodaLocalDate = LocalDate.parse("2010-06-30");
java.time.LocalDate localDate = JodaToJava8Converter.convertLocalDate(jodaLocalDate);
assertEquals("2010-06-30", localDate.toString());
}
Push the change to the feature branch. Travis will run again, and this time all checks should succeed:
The Codecov bot has no choice but to change his mind and edit his original comment to display a friendlier color. After the fix, our pull request even improves the overall code coverage:
We can now confidently merge the pull request.
Now that our code is of high quality, we can release a version of our project. That requires that we set our maven artifact id in the pom.xml to a fixed value (no SNAPSHOT) like this:
<groupId>mafoe</groupId>
<artifactId>working-with-github</artifactId>
<version>1.0</version>
<modelVersion>4.0.0</modelVersion>
Then we push that change to the master branch and create a git tag. It makes sense to name it "1.0". The required git commands would be
git tag 1.0
git push origin 1.0
This automatically counts as a release, but you can add proper release notes on GitHub to convey more information.
From the Jitpack homepage:
Easy to use package repository for Git
Publish your JVM and Android libraries
Go to https://jitpack.io/ and enter the repository's URL (the same you'd use to clone it) into the textbox like this:
Click on "Look up" to make Jitpack grab a list of all released versions and offer to build it. Click on "Get it". Jitpack should build, add a log button...
...and scroll down to a view of how you need to reference your library with the build tool of your choice:
Note that instead of referencing your library with the maven coordinates you chose, the group id is changed to contain your git repository name to make it unique.
Right underneath that, there is a badge. Click on it to access the markdown you need to display the badge in your README.MD. Add the markdown behind your other badges, resulting in:
From the VersionEye homepage:
notifies you about security vulnerabilities, license violations and out-dated dependencies in your Git repositories
Go to https://www.versioneye.com/ and sign up with your GitHub account. Pick the public variant. Authorize versioneye. On the next page, click on your repository. Enable integration for the master branch pom.xml. Navigate to your project, you should see a page like this:
In the above image is also a badge you can click to access the markdown. Add it to your README.MD to make it look like this:
As it turns out, the junit version we used is outdated: 2.7 versus 2.9.9 at the time of writing this. If we updated junit to that version, VersionEye should give us a green badge to show we're up to date. But that's your homework.
This is an example of how the final repository looks like: https://github.com/working-with-github/working-with-github
There are many guides for github online. Here are some:
https://guides.github.com/activities/hello-world/