API 1.0.15b CustomerExerciseDevice standalone

This commit is contained in:
Bossanyi Tibor 2020-11-23 21:18:16 +01:00
parent 3a70bcd10f
commit 11c9a6d112
7 changed files with 130 additions and 45 deletions

View File

@ -2,7 +2,6 @@ package com.aitrainer.api.controller
import com.aitrainer.api.model.Customer import com.aitrainer.api.model.Customer
import com.aitrainer.api.model.User import com.aitrainer.api.model.User
import com.aitrainer.api.repository.CustomerExerciseDeviceRepository
import com.aitrainer.api.service.ServiceBeans import com.aitrainer.api.service.ServiceBeans
import com.aitrainer.api.repository.CustomerRepository import com.aitrainer.api.repository.CustomerRepository
import org.slf4j.LoggerFactory import org.slf4j.LoggerFactory
@ -16,8 +15,7 @@ import javax.validation.Valid
@RestController @RestController
@RequestMapping("/api") @RequestMapping("/api")
class CustomerController ( private val customerRepository: CustomerRepository, class CustomerController ( private val customerRepository: CustomerRepository) {
private val customerExerciseDeviceRepository: CustomerExerciseDeviceRepository ) {
private val logger = LoggerFactory.getLogger(javaClass) private val logger = LoggerFactory.getLogger(javaClass)
@Autowired @Autowired
@ -37,10 +35,6 @@ class CustomerController ( private val customerRepository: CustomerRepository,
@GetMapping("/customers/{id}") @GetMapping("/customers/{id}")
fun getCustomerById(@PathVariable(value = "id") customerId: Long, @RequestHeader headers: HttpHeaders): ResponseEntity<Customer> { fun getCustomerById(@PathVariable(value = "id") customerId: Long, @RequestHeader headers: HttpHeaders): ResponseEntity<Customer> {
val customer: Customer? = customerRepository.findById(customerId).orElse(null) val customer: Customer? = customerRepository.findById(customerId).orElse(null)
if ( customer != null) {
val list = customerExerciseDeviceRepository.findByCustomerId(customer.customerId)
customer.exerciseDevices = list
}
return if (customer == null) ResponseEntity.notFound().build() else ResponseEntity.ok().body(customer) return if (customer == null) ResponseEntity.notFound().build() else ResponseEntity.ok().body(customer)
} }
@ -48,10 +42,7 @@ class CustomerController ( private val customerRepository: CustomerRepository,
@GetMapping("/customers/find_by_firebaseuid/{uid}") @GetMapping("/customers/find_by_firebaseuid/{uid}")
fun getCustomerByFirebaseUid(@PathVariable(value = "uid") firebaseUid: String): ResponseEntity<Customer> { fun getCustomerByFirebaseUid(@PathVariable(value = "uid") firebaseUid: String): ResponseEntity<Customer> {
val customer: Customer? = customerRepository.findByFirebaseUid(firebaseUid) val customer: Customer? = customerRepository.findByFirebaseUid(firebaseUid)
if ( customer != null) {
val list = customerExerciseDeviceRepository.findByCustomerId(customer.customerId)
customer.exerciseDevices = list
}
return if (customer == null) ResponseEntity.notFound().build() else ResponseEntity.ok().body(customer) return if (customer == null) ResponseEntity.notFound().build() else ResponseEntity.ok().body(customer)
} }
@ -59,10 +50,6 @@ class CustomerController ( private val customerRepository: CustomerRepository,
@GetMapping("/customers/find_by_email/{email}") @GetMapping("/customers/find_by_email/{email}")
fun getCustomerByEmail(@PathVariable(value = "email") email: String): ResponseEntity<Customer> { fun getCustomerByEmail(@PathVariable(value = "email") email: String): ResponseEntity<Customer> {
val customer: Customer? = customerRepository.findByEmail(email) val customer: Customer? = customerRepository.findByEmail(email)
if ( customer != null) {
val list = customerExerciseDeviceRepository.findByCustomerId(customer.customerId)
customer.exerciseDevices = list
}
return if (customer == null) ResponseEntity.notFound().build() else ResponseEntity.ok().body(customer) return if (customer == null) ResponseEntity.notFound().build() else ResponseEntity.ok().body(customer)
} }
@ -89,7 +76,7 @@ class CustomerController ( private val customerRepository: CustomerRepository,
val returnCustomer: Customer = customerRepository.findById(customerId).orElse(null) val returnCustomer: Customer = customerRepository.findById(customerId).orElse(null)
?: return ResponseEntity.notFound().build() ?: return ResponseEntity.notFound().build()
returnCustomer.firebaseUid = firebaseUid; returnCustomer.firebaseUid = firebaseUid
return ResponseEntity.ok().body(customerRepository.save(returnCustomer)) return ResponseEntity.ok().body(customerRepository.save(returnCustomer))
} }

View File

@ -0,0 +1,32 @@
package com.aitrainer.api.controller
import com.aitrainer.api.model.CustomerExerciseDevice
import com.aitrainer.api.repository.CustomerExerciseDeviceRepository
import org.slf4j.LoggerFactory
import org.springframework.http.ResponseEntity
import org.springframework.web.bind.annotation.*
import javax.validation.Valid
@RestController
@RequestMapping("/api")
class CustomerExerciseDeviceController(private val customerExerciseDeviceRepository: CustomerExerciseDeviceRepository) {
private val logger = LoggerFactory.getLogger(javaClass)
@GetMapping("/customer_exercise_device/customer/{id}")
fun getAllByCustomerId(@PathVariable(value = "id") customerId: Long): ResponseEntity<List<CustomerExerciseDevice>> {
val deviceList = customerExerciseDeviceRepository.findByCustomerId(customerId)
logger.info("Get all devices by customerId $deviceList")
return if(deviceList.isNotEmpty())
ResponseEntity.ok().body(deviceList) else
ResponseEntity.notFound().build()
}
@PostMapping("/customer_exercise_device")
fun insertDevice(@Valid @RequestBody customerExerciseDevice: CustomerExerciseDevice): ResponseEntity<CustomerExerciseDevice> {
val newCustomerExerciseDevice = customerExerciseDeviceRepository.save(customerExerciseDevice)
logger.info("Create new device: $newCustomerExerciseDevice")
return ResponseEntity.ok().body(newCustomerExerciseDevice)
}
}

View File

@ -1,7 +1,5 @@
package com.aitrainer.api.model package com.aitrainer.api.model
import org.hibernate.annotations.Fetch
import org.hibernate.annotations.FetchMode
import javax.persistence.* import javax.persistence.*
@Entity @Entity
@ -20,7 +18,6 @@ data class Customer (
var trainerId: Long = 0, var trainerId: Long = 0,
var password: String? = "", var password: String? = "",
var birthYear:Int = 0, var birthYear:Int = 0,
// var weight: Int = 0,
var goal: String? = null, var goal: String? = null,
var fitnessLevel: String = "beginner", var fitnessLevel: String = "beginner",
var bodyType: String? = null, var bodyType: String? = null,
@ -28,8 +25,4 @@ data class Customer (
@Id @GeneratedValue(strategy = GenerationType.IDENTITY) @Id @GeneratedValue(strategy = GenerationType.IDENTITY)
var customerId: Long = 0 var customerId: Long = 0
) { )
@OneToMany(cascade = [(CascadeType.ALL)], fetch = FetchType.EAGER, mappedBy = "customer")
@Fetch(value = FetchMode.SUBSELECT)
var exerciseDevices: List<CustomerExerciseDevice> = mutableListOf<CustomerExerciseDevice>()
}

View File

@ -12,14 +12,9 @@ data class CustomerExerciseDevice (
@GeneratedValue(strategy = GenerationType.IDENTITY) @GeneratedValue(strategy = GenerationType.IDENTITY)
val customerExerciseDeviceId: Long = 0, val customerExerciseDeviceId: Long = 0,
@get: NotNull var exerciseDeviceId: Long?, @get: NotNull var exerciseDeviceId: Long?,
//@get: NotNull var customerId: Long?, @get: NotNull var customerId: Long?,
@get: NotNull var favourite: Boolean?, @get: NotNull var favourite: Boolean?,
@get: NotNull var dateAdd: String? = null @get: NotNull var dateAdd: String? = null
) { )
@ManyToOne(fetch = FetchType.EAGER, optional = false)
@JoinColumn(name = "customerId", nullable = false)
@JsonIgnore
val customer: Customer? = null
}

View File

@ -8,7 +8,7 @@ import org.springframework.stereotype.Repository
@Repository @Repository
interface CustomerExerciseDeviceRepository: JpaRepository<CustomerExerciseDevice, Long> { interface CustomerExerciseDeviceRepository: JpaRepository<CustomerExerciseDevice, Long> {
@Query(" FROM CustomerExerciseDevice " + @Query(" FROM CustomerExerciseDevice " +
" WHERE customer.customerId = :customerId" " WHERE customerId = :customerId"
) )
fun findByCustomerId(customerId: Long): List<CustomerExerciseDevice> fun findByCustomerId(customerId: Long): List<CustomerExerciseDevice>
} }

View File

@ -0,0 +1,59 @@
package com.aitrainer.api.test
import com.aitrainer.api.controller.CustomerExerciseDeviceController
import com.aitrainer.api.controller.PurchaseController
import com.aitrainer.api.model.Customer
import com.aitrainer.api.model.CustomerExerciseDevice
import com.aitrainer.api.repository.CustomerExerciseDeviceRepository
import org.junit.jupiter.api.Test
import org.junit.jupiter.api.TestInstance
import org.springframework.beans.factory.annotation.Autowired
import org.springframework.boot.test.context.SpringBootTest
import kotlin.test.assertEquals
import kotlin.test.assertTrue
@SpringBootTest
@TestInstance(TestInstance.Lifecycle.PER_CLASS)
class CustomerExerciseDeviceTest {
@Autowired
private lateinit var customerExerciseDeviceRepository: CustomerExerciseDeviceRepository
@Test
fun testGetPurchaseByCustomerId() {
val controller = CustomerExerciseDeviceController(customerExerciseDeviceRepository)
val response = controller.getAllByCustomerId(90)
val devices = response.body
assertTrue(devices is List)
assertTrue(devices.isNotEmpty())
assertEquals(devices.size, 2)
assertEquals(devices[0].exerciseDeviceId, 1)
assertEquals(devices[0].customerId, 90)
}
@Test
fun testDeviceInsert() {
val customerExerciseDevice = CustomerExerciseDevice(
exerciseDeviceId = 3,
favourite = false,
dateAdd = "2020-11-23 04:32:00",
customerId = 62
)
val controller = CustomerExerciseDeviceController(customerExerciseDeviceRepository)
val response = controller.insertDevice(customerExerciseDevice)
val customerDeviceNew = response.body
assertEquals(customerDeviceNew!!.customerId, 62)
assertEquals(customerDeviceNew.exerciseDeviceId, 3)
customerExerciseDeviceRepository.delete(customerDeviceNew)
}
}

View File

@ -3,7 +3,6 @@ package com.aitrainer.api.test
import com.aitrainer.api.controller.CustomerController import com.aitrainer.api.controller.CustomerController
import com.aitrainer.api.model.Customer import com.aitrainer.api.model.Customer
import com.aitrainer.api.model.User import com.aitrainer.api.model.User
import com.aitrainer.api.repository.CustomerExerciseDeviceRepository
import com.aitrainer.api.repository.CustomerRepository import com.aitrainer.api.repository.CustomerRepository
import com.aitrainer.api.service.ServiceBeans import com.aitrainer.api.service.ServiceBeans
import org.junit.jupiter.api.BeforeAll import org.junit.jupiter.api.BeforeAll
@ -32,8 +31,6 @@ class CustomerTests {
@Autowired @Autowired
private lateinit var customerRepository: CustomerRepository private lateinit var customerRepository: CustomerRepository
@Autowired
private lateinit var customerExerciseDeviceRepository: CustomerExerciseDeviceRepository
private var insertedId: Long? = null private var insertedId: Long? = null
@ -44,15 +41,13 @@ class CustomerTests {
assertEquals( customer.name, "Átlag 18 éves fiú") assertEquals( customer.name, "Átlag 18 éves fiú")
val id2: Long = 90 val id2: Long = 90
val controller = CustomerController(customerRepository, customerExerciseDeviceRepository) val controller = CustomerController(customerRepository)
val response = controller.getCustomerById(id2, HttpHeaders.EMPTY) val response = controller.getCustomerById(id2, HttpHeaders.EMPTY)
val customer2: Customer = response.body as Customer val customer2: Customer = response.body as Customer
assertNotNull (customer2) assertNotNull (customer2)
assertEquals(customer2.email, "sw@andio.biz") assertEquals(customer2.email, "sw@andio.biz")
assertEquals(customer2.exerciseDevices.size, 2)
assertEquals(customer2.exerciseDevices[0].exerciseDeviceId, 1)
} }
@Test @Test
@ -61,7 +56,6 @@ class CustomerTests {
val customers: List<Customer> = customerRepository.findByTrainerId( id ) val customers: List<Customer> = customerRepository.findByTrainerId( id )
assertEquals(customers.count(), 3) assertEquals(customers.count(), 3)
assertEquals( customers[0].name, "Átlag 13 éves fiú") assertEquals( customers[0].name, "Átlag 13 éves fiú")
assertEquals(customers[0].exerciseDevices.size, 0)
} }
@Test @Test
@ -134,7 +128,7 @@ class CustomerTests {
//customer.weight = 79 //customer.weight = 79
customer.birthYear = 1972 customer.birthYear = 1972
val customerController = CustomerController(customerRepository, customerExerciseDeviceRepository) val customerController = CustomerController(customerRepository)
var response: ResponseEntity<*> = customerController.updateCustomerById(id, customer, HttpHeaders.readOnlyHttpHeaders(HttpHeaders.EMPTY) ) var response: ResponseEntity<*> = customerController.updateCustomerById(id, customer, HttpHeaders.readOnlyHttpHeaders(HttpHeaders.EMPTY) )
print ("body " + response.body) print ("body " + response.body)
var newCustomer: Customer? = response.body as Customer var newCustomer: Customer? = response.body as Customer
@ -174,7 +168,7 @@ class CustomerTests {
password = user.password password = user.password
firebaseUid = user.firebaseUid firebaseUid = user.firebaseUid
} }
val customerController = CustomerController(customerRepository,customerExerciseDeviceRepository) val customerController = CustomerController(customerRepository)
customerController.serviceBeans = serviceBean customerController.serviceBeans = serviceBean
var response: ResponseEntity<*> = customerController.registration(json) var response: ResponseEntity<*> = customerController.registration(json)
print("body " + response.body) print("body " + response.body)
@ -197,7 +191,7 @@ class CustomerTests {
insertedId = savedCustomer.customerId insertedId = savedCustomer.customerId
val customerController = CustomerController(customerRepository,customerExerciseDeviceRepository) val customerController = CustomerController(customerRepository)
val response: ResponseEntity<*> = customerController.updateCustomerFirebaseUidById(insertedId!!, "3FirebusaeId4") val response: ResponseEntity<*> = customerController.updateCustomerFirebaseUidById(insertedId!!, "3FirebusaeId4")
val newCustomer2: Customer = response.body as Customer val newCustomer2: Customer = response.body as Customer
assertEquals(response.statusCode, HttpStatus.OK) assertEquals(response.statusCode, HttpStatus.OK)
@ -212,7 +206,7 @@ class CustomerTests {
@Test @Test
fun testGetCustomerByFirebaseUid() { fun testGetCustomerByFirebaseUid() {
val uid = "3FirebaseU1d" val uid = "3FirebaseU1d"
val customerController = CustomerController(customerRepository,customerExerciseDeviceRepository) val customerController = CustomerController(customerRepository)
val response: ResponseEntity<*> = customerController.getCustomerByFirebaseUid(uid) val response: ResponseEntity<*> = customerController.getCustomerByFirebaseUid(uid)
assertEquals(response.statusCode, HttpStatus.OK) assertEquals(response.statusCode, HttpStatus.OK)
val newCustomer: Customer = response.body as Customer val newCustomer: Customer = response.body as Customer
@ -224,7 +218,7 @@ class CustomerTests {
@Test @Test
fun testGetCustomerByEmail() { fun testGetCustomerByEmail() {
val email = "sw2@andio.biz" val email = "sw2@andio.biz"
val customerController = CustomerController(customerRepository,customerExerciseDeviceRepository) val customerController = CustomerController(customerRepository)
val response: ResponseEntity<*> = customerController.getCustomerByEmail(email) val response: ResponseEntity<*> = customerController.getCustomerByEmail(email)
assertEquals(response.statusCode, HttpStatus.OK) assertEquals(response.statusCode, HttpStatus.OK)
@ -233,10 +227,35 @@ class CustomerTests {
assertEquals(newCustomer.name, "Bos") assertEquals(newCustomer.name, "Bos")
assertEquals(newCustomer.email, "sw2@andio.biz") assertEquals(newCustomer.email, "sw2@andio.biz")
assertEquals(newCustomer.firebaseUid, "3FirebaseU1d") assertEquals(newCustomer.firebaseUid, "3FirebaseU1d")
assertEquals(newCustomer.exerciseDevices.size, 0)
} }
/*@Test
fun testAddCustomerExerciseDevice() {
val customer: Customer = customerRepository.findById(103) .orElse(null)
val customerExerciseDevice = CustomerExerciseDevice(
exerciseDeviceId = 1,
favourite = false,
dateAdd = "2020-11-23 20:00"
)
customerExerciseDevice.customer = customer
val listDevice : List<CustomerExerciseDevice> = listOf(customerExerciseDevice)
customer.exerciseDevices = listDevice
val newCustomer: Customer = customerRepository.save(customer)
assertEquals(newCustomer.email, "sw2@andio.biz")
assertEquals(newCustomer.exerciseDevices.size, 1)
assertEquals(newCustomer.exerciseDevices[0].exerciseDeviceId, 1)
val deletedList: List<CustomerExerciseDevice> = listOf()
customer.exerciseDevices = deletedList
val newCustomer2 = customerRepository.save(customer)
assertEquals(newCustomer2.email, "sw2@andio.biz")
assertEquals(newCustomer2.exerciseDevices.size, 0)
}
*/
/*@Test fun _testLogin() { /*@Test fun _testLogin() {
val json = "{\"username\":\"bosi2@example.com\",\"password\":\"94333385\"}" val json = "{\"username\":\"bosi2@example.com\",\"password\":\"94333385\"}"
val user: User = User().fromJson(json) val user: User = User().fromJson(json)