Skip to content
Open
Show file tree
Hide file tree
Changes from all 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
13 changes: 13 additions & 0 deletions src/main/java/com/ironhack/lab_jpa/LabJpaApplication.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package com.ironhack.lab_jpa;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class LabJpaApplication {

public static void main(String[] args) {
SpringApplication.run(LabJpaApplication.class, args);
}

}
59 changes: 59 additions & 0 deletions src/main/java/com/ironhack/lab_jpa/models/Person.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,59 @@
package com.ironhack.lab_jpa.models;

import jakarta.persistence.*;

@Entity
@Table(name = "person")
public class Person {

@Id
@GeneratedValue(strategy = jakarta.persistence.GenerationType.IDENTITY)
private Long id;

@Column(nullable = false,name = "NAME")
private String name;

@Column(nullable = false,name = "AGE")
private int age;

public Person( String name, int age) {
this.name = name;
this.age = age;
}

public Person() {
}

public long getId() {
return id;
}

public void setId(long id) {
this.id = id;
}

public String getName() {
return name;
}

public void setName(String name) {
this.name = name;
}

public int getAge() {
return age;
}

public void setAge(int age) {
this.age = age;
}

@Override
public String toString() {
return "Person{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
'}';
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
package com.ironhack.lab_jpa.repositories;

import com.ironhack.lab_jpa.models.Person;
import org.springframework.data.jpa.repository.JpaRepository;

public interface PersonRepository extends JpaRepository<Person, Long> {
// Custom query methods can be defined here if needed

}
4 changes: 4 additions & 0 deletions src/main/resources/application.properties
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
spring.application.name=lab-jpa
spring.datasource.url=jdbc:mysql://localhost:3306/lab_jpa
spring.datasource.username=root
spring.datasource.password=Raticida1963
13 changes: 13 additions & 0 deletions src/test/java/com/ironhack/lab_jpa/LabJpaApplicationTests.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
package com.ironhack.lab_jpa;

import org.junit.jupiter.api.Test;
import org.springframework.boot.test.context.SpringBootTest;

@SpringBootTest
class LabJpaApplicationTests {

@Test
void contextLoads() {
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,88 @@
package com.ironhack.lab_jpa.repositories;

import com.ironhack.lab_jpa.models.Person;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.sql.SQLOutput;
import java.util.ArrayList;
import java.util.List;
import java.util.Optional;

import static org.junit.jupiter.api.Assertions.*;

@SpringBootTest
public class PersonRepositoryTest {

@Autowired
private PersonRepository personRepository;

@Test
public void testSave() {
// Implement the test logic here
Person person = new Person("John Doe", 30);
personRepository.save(person);

Optional<Person> foundPerson = personRepository.findById(person.getId());
assertNotNull(foundPerson);
System.out.println("Found person: " + foundPerson);
assertNotNull(foundPerson.get().getId());
assertEquals("John Doe", foundPerson.get().getName());
assertEquals(30, foundPerson.get().getAge());

}

@Test
public void testFindAll() {
// Implement the test logic here
ArrayList<Person> people = new ArrayList<>();
people.add(new Person("Ditto", 10));
people.add(new Person("John", 20));
people.add(new Person("Pepe", 10));
personRepository.saveAll(people);

List<Person> all = personRepository.findAll();
System.out.println("All people: " + all);
assertNotNull(all);
assertEquals(3, all.size());
assertEquals("Ditto", all.get(0).getName());
assertEquals(30, all.get(0).getAge());


}

@Test
public void testDelete() {
Person person = new Person("John Doe", 30);
personRepository.save(person);
Optional<Person> foundPerson = personRepository.findById(person.getId());
assertNotNull(foundPerson);
personRepository.delete(person);
Optional<Person> notfoundPerson = personRepository.findById(person.getId());
assertTrue(notfoundPerson.isEmpty());

System.out.println("Found person: " + foundPerson);


}

@Test
public void testUpdate() {
// Implement the test logic here
Person person = new Person("John Doe", 15);
personRepository.save(person);
Optional<Person> foundPerson = personRepository.findById(person.getId());
assertNotNull(foundPerson);
person.setName("Nuevo nombre");
person.setAge(30);
personRepository.save(person);
Optional<Person> foundPerson2 = personRepository.findById(person.getId());
assertNotNull(foundPerson2);
System.out.println("Found person: " + foundPerson2);
assertNotNull(foundPerson2.get().getId());
assertEquals("Nuevo nombre", foundPerson2.get().getName());
assertEquals(30, foundPerson2.get().getAge());

}
}