Skip to content
Snippets Groups Projects
Commit 28b8fb90 authored by Colin DAMON's avatar Colin DAMON
Browse files

Employee report 2

parent 80a69711
No related branches found
No related tags found
1 merge request!97Resolve "Employee report 2"
...@@ -42,3 +42,4 @@ include: ...@@ -42,3 +42,4 @@ include:
- local: "/java-memoizers/.gitlab-ci.yml" - local: "/java-memoizers/.gitlab-ci.yml"
- local: "/markov-chain/.gitlab-ci.yml" - local: "/markov-chain/.gitlab-ci.yml"
- local: "/names/.gitlab-ci.yml" - local: "/names/.gitlab-ci.yml"
- local: "/employee-report-2/.gitlab-ci.yml"
package-employee-report-2:
variables:
PROJECT_FOLDER: "employee-report-2"
extends: .java
only:
refs:
- master
- merge_requests
changes:
- ".gitlab-common-ci.yml"
- "employee-report-2/**/*"
<?xml version="1.0" encoding="UTF-8"?>
<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">
<modelVersion>4.0.0</modelVersion>
<parent>
<version>1.0.0</version>
<groupId>fr.ippon.kata</groupId>
<artifactId>java-parent</artifactId>
<relativePath>../java-parent</relativePath>
</parent>
<version>1.0.0-SNAPSHOT</version>
<artifactId>employee-report-2</artifactId>
<name>EmployeeReport2</name>
<developers>
<developer>
<email>kgrammont@ippon.fr</email>
<name>Ketil GRAMMONT</name>
</developer>
<developer>
<email>cdamon@ippon.fr</email>
<name>Colin DAMON</name>
</developer>
</developers>
</project>
# Employee report
Résolution en TDD et en Java du kata [EmployeeReport](https://codingdojo.org/kata/Employee-Report/).
- **Auteurs** : Ketil GRAMMONT et Colin DAMON
- **Date** : 13/10/2021
- **Langage** : Java
- **Niveau** : Facile
- **Replay** : [Twitch](https://www.twitch.tv/videos/1175612810)
package fr.ippon.employee;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public record Employee(String name, int age) {
private static Pattern NAME_PATTERN = Pattern
.compile("(\\p{L}+)(\\P{L}*)");
public Employee(String name, int age) {
this.name = format(name);
this.age = age;
}
private String format(String name) {
Matcher matcher = NAME_PATTERN.matcher(name);
StringBuilder result = new StringBuilder();
while (matcher.find()) {
result.append(capitalize(matcher.group(1)))
.append(matcher.group(2));
}
return result.toString();
}
private String capitalize(String word) {
return word.substring(0, 1)
.toUpperCase()
+ word.substring(1, word.length())
.toLowerCase();
}
boolean isAdult() {
return age >= 18;
}
}
package fr.ippon.employee;
import java.util.Collection;
import java.util.Comparator;
import java.util.List;
public class Employees {
private final List<Employee> employees;
public Employees(Employee... employees) {
this.employees = List.of(employees);
}
public Collection<Employee> get() {
return employees;
}
public Collection<String> sundayWorkers() {
return employees.stream()
.filter(Employee::isAdult)
.map(Employee::name)
.sorted(Comparator.reverseOrder())
.toList();
}
}
package fr.ippon.employee;
import static org.assertj.core.api.Assertions.*;
import org.junit.jupiter.api.Test;
class EmployeeReportTest {
@Test
void shouldGetEmployees() {
Employees employees = new Employees(mike());
assertThat(employees.get()).containsExactly(mike());
}
@Test
void shouldGetUnmodifiableEmployees() {
assertThatThrownBy(() -> new Employees().get()
.clear()).isExactlyInstanceOf(
UnsupportedOperationException.class);
}
@Test
void shouldGetSundayWorkers() {
Employees employees = new Employees(
new Employee("Max", 17), mike(),
new Employee("jean charles", 18));
assertThat(employees.sundayWorkers())
.containsExactly("Mike", "Jean Charles");
}
private Employee mike() {
return new Employee("MIKE", 51);
}
}
package fr.ippon.employee;
import static org.assertj.core.api.Assertions.*;
import org.junit.jupiter.api.Test;
class EmployeeTest {
@Test
void shouldCapitalizeSimpleName() {
Employee employee = new Employee("jeaN", 14);
assertThat(employee.name()).isEqualTo("Jean");
}
@Test
void shouldCapitalizeComposedName() {
Employee employee = new Employee("jean-charles", 14);
assertThat(employee.name()).isEqualTo("Jean-Charles");
}
@Test
void shouldCapitalizeComposedNameWithAccents() {
Employee employee = new Employee("jean jérémie", 14);
assertThat(employee.name()).isEqualTo("Jean Jérémie");
}
}
...@@ -27,6 +27,7 @@ Un kata de code est un petit exercice pensé pour s'entrainer jusqu'à maitriser ...@@ -27,6 +27,7 @@ Un kata de code est un petit exercice pensé pour s'entrainer jusqu'à maitriser
- [Fizz Buzz](/fizz-buzz) - [Fizz Buzz](/fizz-buzz)
- [Leap years](/leap-years) - [Leap years](/leap-years)
- [Employee report](/employee-report) - [Employee report](/employee-report)
- [Employee report 2](/employee-report-2)
### Moyen ### Moyen
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment