Compare commits
13 Commits
feature/ci
...
feature-te
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
3fe0f99d28 | ||
|
|
5a33fdc557 | ||
|
|
1f487f5f1e | ||
|
|
8404775d1f | ||
|
|
6babdf33cb | ||
|
|
f842d55ed2 | ||
|
|
f08e6e83f2 | ||
|
|
0205396449 | ||
|
|
9037623604 | ||
|
|
a1ce73f535 | ||
|
|
ec8b84b630 | ||
|
|
aa6be34cd7 | ||
|
|
9dde1ef038 |
21
Jenkinsfile
vendored
21
Jenkinsfile
vendored
@@ -6,7 +6,7 @@ pipeline {
|
||||
|
||||
steps {
|
||||
withMaven(maven : 'maven_3_5_0') {
|
||||
sh 'mvn clean compile'
|
||||
sh 'mvn clean install'
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -20,24 +20,13 @@ pipeline {
|
||||
}
|
||||
}
|
||||
|
||||
stage ('Deploy?') {
|
||||
stage('Generate HTML report') {
|
||||
steps {
|
||||
input('Do you want to deploy?')
|
||||
cucumber buildStatus: "UNSTABLE",
|
||||
fileIncludePattern: '**/cucumber.json',
|
||||
jsonReportDirectory: 'target'
|
||||
}
|
||||
}
|
||||
|
||||
stage ('Deployment Stage') {
|
||||
steps {
|
||||
|
||||
withCredentials([[$class: 'UsernamePasswordMultiBinding', credentialsId: 'PCF_LOGIN',
|
||||
usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD']]) {
|
||||
|
||||
sh '/usr/local/bin/cf login -a http://api.run.pivotal.io -u $USERNAME -p $PASSWORD'
|
||||
sh '/usr/local/bin/cf push'
|
||||
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
28
pom.xml
28
pom.xml
@@ -12,8 +12,6 @@
|
||||
<properties>
|
||||
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
|
||||
<java.version>1.8</java.version>
|
||||
<junit.jupiter.version>5.0.0-M3</junit.jupiter.version>
|
||||
<junit.platform.version>1.0.0-M3</junit.platform.version>
|
||||
</properties>
|
||||
|
||||
<build>
|
||||
@@ -31,9 +29,9 @@
|
||||
<version>2.19</version>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.junit.platform</groupId>
|
||||
<artifactId>junit-platform-surefire-provider</artifactId>
|
||||
<version>1.0.0-M3</version>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>4.12</version>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</plugin>
|
||||
@@ -41,16 +39,22 @@
|
||||
</build>
|
||||
|
||||
<dependencies>
|
||||
|
||||
<dependency>
|
||||
<groupId>org.junit.jupiter</groupId>
|
||||
<artifactId>junit-jupiter-engine</artifactId>
|
||||
<version>5.0.0-M3</version>
|
||||
<scope>test</scope>
|
||||
<groupId>info.cukes</groupId>
|
||||
<artifactId>cucumber-java</artifactId>
|
||||
<version>1.2.5</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.junit.platform</groupId>
|
||||
<artifactId>junit-platform-runner</artifactId>
|
||||
<version>${junit.platform.version}</version>
|
||||
<groupId>info.cukes</groupId>
|
||||
<artifactId>cucumber-junit</artifactId>
|
||||
<version>1.2.5</version>
|
||||
</dependency>
|
||||
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>4.12</version>
|
||||
</dependency>
|
||||
|
||||
</dependencies>
|
||||
|
||||
@@ -5,10 +5,16 @@ public class FizzBuzz {
|
||||
public String play(int number) {
|
||||
|
||||
if (number == 0) throw new IllegalArgumentException("Number must not be 0");
|
||||
if (number % 3 == 0) return "Fizz";
|
||||
if (number % 5 == 0) return "Buzz";
|
||||
|
||||
if (isMultipleOf(number, 3) && isMultipleOf(number, 5)) return "FizzBuzz";
|
||||
if (isMultipleOf(number, 3)) return "Fizz";
|
||||
if (isMultipleOf(number, 5)) return "Buzz";
|
||||
|
||||
|
||||
return String.valueOf(number);
|
||||
}
|
||||
|
||||
private boolean isMultipleOf(int number, int i) {
|
||||
return number % i == 0;
|
||||
}
|
||||
}
|
||||
|
||||
14
src/test/java/com/techprimers/testing/CucumberTest.java
Normal file
14
src/test/java/com/techprimers/testing/CucumberTest.java
Normal file
@@ -0,0 +1,14 @@
|
||||
package com.techprimers.testing;
|
||||
|
||||
import cucumber.api.CucumberOptions;
|
||||
import cucumber.api.junit.Cucumber;
|
||||
import org.junit.runner.RunWith;
|
||||
|
||||
@RunWith(Cucumber.class)
|
||||
@CucumberOptions(
|
||||
features = "src/test/resources",
|
||||
glue = "com.techprimers.testing",
|
||||
format = {"json:target/cucumber.json"}
|
||||
)
|
||||
public class CucumberTest {
|
||||
}
|
||||
26
src/test/java/com/techprimers/testing/FizzBuzzStepdefs.java
Normal file
26
src/test/java/com/techprimers/testing/FizzBuzzStepdefs.java
Normal file
@@ -0,0 +1,26 @@
|
||||
package com.techprimers.testing;
|
||||
|
||||
import cucumber.api.java.en.Given;
|
||||
import cucumber.api.java.en.Then;
|
||||
import cucumber.api.java.en.When;
|
||||
import org.junit.Assert;
|
||||
public class FizzBuzzStepdefs {
|
||||
|
||||
FizzBuzz fizzBuzz;
|
||||
String result;
|
||||
|
||||
@Given("^Create a FizzBuzz game play$")
|
||||
public void createAFizzBuzzGamePlay() throws Throwable {
|
||||
fizzBuzz = new FizzBuzz();
|
||||
}
|
||||
|
||||
@When("^I play with number (\\d+)$")
|
||||
public void iPlayWithNumber(int number) throws Throwable {
|
||||
result = fizzBuzz.play(number);
|
||||
}
|
||||
|
||||
@Then("^The result is \"([^\"]*)\"$")
|
||||
public void theResultIs(String resultString) throws Throwable {
|
||||
Assert.assertEquals(result, resultString);
|
||||
}
|
||||
}
|
||||
@@ -1,46 +1,51 @@
|
||||
package com.techprimers.testing;
|
||||
|
||||
import org.junit.jupiter.api.*;
|
||||
import org.junit.After;
|
||||
import org.junit.Assert;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
||||
class FizzBuzzTest {
|
||||
public class FizzBuzzTest {
|
||||
|
||||
public FizzBuzz fB;
|
||||
|
||||
@BeforeEach
|
||||
// @
|
||||
@Before
|
||||
public void setUp() {
|
||||
fB = new FizzBuzz();
|
||||
}
|
||||
|
||||
@DisplayName("Play FizzBuzz with number = 1")
|
||||
// @DisplayName("Play FizzBuzz with number = 1")
|
||||
@Test
|
||||
public void testNumber() {
|
||||
String fizzBuzz = fB.play(1);
|
||||
Assertions.assertEquals(fizzBuzz, "1");
|
||||
Assert.assertEquals(fizzBuzz, "1");
|
||||
}
|
||||
|
||||
@DisplayName("Play FizzBuzz with number = 3")
|
||||
// @DisplayName("Play FizzBuzz with number = 3")
|
||||
@Test
|
||||
public void testFizz() {
|
||||
String fizzBuzz = fB.play(3);
|
||||
Assertions.assertEquals(fizzBuzz, "Fizz");
|
||||
Assert.assertEquals(fizzBuzz, "Fizz");
|
||||
}
|
||||
|
||||
@DisplayName("Play FizzBuzz with number = 5")
|
||||
// @DisplayName("Play FizzBuzz with number = 5")
|
||||
@Test
|
||||
public void testBuzz() {
|
||||
String fizzBuzz = fB.play(5);
|
||||
Assertions.assertEquals(fizzBuzz, "Buzz");
|
||||
Assert.assertEquals(fizzBuzz, "Buzz");
|
||||
}
|
||||
|
||||
@DisplayName("Don't Play FizzBuzz with number = 0")
|
||||
@Test
|
||||
public void testZero() {
|
||||
// @DisplayName("Don't Play FizzBuzz with number = 0")
|
||||
// @Test
|
||||
// public void testZero() {
|
||||
//
|
||||
// Assert.assertThat(IllegalArgumentException.class,
|
||||
// () -> fB.play(0));
|
||||
// }
|
||||
|
||||
Assertions.assertThrows(IllegalArgumentException.class,
|
||||
() -> fB.play(0));
|
||||
}
|
||||
|
||||
@AfterEach
|
||||
// @AfterEach
|
||||
@After
|
||||
public void tearDown() {
|
||||
fB = null;
|
||||
}
|
||||
|
||||
16
src/test/resources/FizzBuzz.feature
Normal file
16
src/test/resources/FizzBuzz.feature
Normal file
@@ -0,0 +1,16 @@
|
||||
Feature: FizzBuzz Game play
|
||||
|
||||
Scenario: Play FizzBuzz to get Fizz
|
||||
Given Create a FizzBuzz game play
|
||||
When I play with number 3
|
||||
Then The result is "Fizz"
|
||||
|
||||
Scenario: Play FizzBuzz to get Buzz
|
||||
Given Create a FizzBuzz game play
|
||||
When I play with number 5
|
||||
Then The result is "Buzz"
|
||||
|
||||
Scenario: Play FizzBuzz to get FizzBuzz
|
||||
Given Create a FizzBuzz game play
|
||||
When I play with number 15
|
||||
Then The result is "FizzBuzz"
|
||||
Reference in New Issue
Block a user