diff --git a/.jhipster/Game.json b/.jhipster/Game.json new file mode 100644 index 0000000..2bb904c --- /dev/null +++ b/.jhipster/Game.json @@ -0,0 +1,28 @@ +{ + "name": "Game", + "fields": [ + { + "fieldName": "name", + "fieldType": "String" + } + ], + "relationships": [ + { + "relationshipType": "one-to-many", + "otherEntityName": "gameCommission", + "otherEntityRelationshipName": "game", + "relationshipName": "gameCommission" + } + ], + "changelogDate": "20200328164300", + "entityTableName": "game", + "dto": "no", + "pagination": "no", + "service": "no", + "jpaMetamodelFiltering": false, + "fluentMethods": true, + "readOnly": false, + "embedded": false, + "clientRootFolder": "", + "applications": "*" +} \ No newline at end of file diff --git a/.jhipster/GameCommission.json b/.jhipster/GameCommission.json new file mode 100644 index 0000000..3d81fec --- /dev/null +++ b/.jhipster/GameCommission.json @@ -0,0 +1,36 @@ +{ + "name": "GameCommission", + "fields": [ + { + "fieldName": "commission", + "fieldType": "Integer" + } + ], + "relationships": [ + { + "relationshipType": "many-to-one", + "otherEntityName": "gameUser", + "otherEntityRelationshipName": "commission", + "relationshipName": "gameUser", + "otherEntityField": "id" + }, + { + "relationshipType": "many-to-one", + "otherEntityName": "game", + "otherEntityRelationshipName": "gameCommission", + "relationshipName": "game", + "otherEntityField": "id" + } + ], + "changelogDate": "20200328164200", + "entityTableName": "game_commission", + "dto": "no", + "pagination": "no", + "service": "no", + "jpaMetamodelFiltering": false, + "fluentMethods": true, + "readOnly": false, + "embedded": false, + "clientRootFolder": "", + "applications": "*" +} \ No newline at end of file diff --git a/.jhipster/GameUser.json b/.jhipster/GameUser.json new file mode 100644 index 0000000..d2bcc00 --- /dev/null +++ b/.jhipster/GameUser.json @@ -0,0 +1,32 @@ +{ + "name": "GameUser", + "fields": [ + { + "fieldName": "username", + "fieldType": "String" + }, + { + "fieldName": "password", + "fieldType": "String" + } + ], + "relationships": [ + { + "relationshipType": "one-to-many", + "otherEntityName": "gameCommission", + "otherEntityRelationshipName": "gameUser", + "relationshipName": "commission" + } + ], + "changelogDate": "20200328164100", + "entityTableName": "game_user", + "dto": "no", + "pagination": "no", + "service": "no", + "jpaMetamodelFiltering": false, + "fluentMethods": true, + "readOnly": false, + "embedded": false, + "clientRootFolder": "", + "applications": "*" +} \ No newline at end of file diff --git a/admin.jh b/admin.jh new file mode 100644 index 0000000..12e8d5c --- /dev/null +++ b/admin.jh @@ -0,0 +1,17 @@ +entity GameUser { + username String + password String +} + +entity GameCommission { + commission Integer +} + +entity Game { + name String +} + +relationship OneToMany { + GameUser{commission} to GameCommission + Game to GameCommission{game} +} \ No newline at end of file diff --git a/src/main/java/com/mycompany/myapp/config/CacheConfiguration.java b/src/main/java/com/mycompany/myapp/config/CacheConfiguration.java index fd8baed..b949072 100644 --- a/src/main/java/com/mycompany/myapp/config/CacheConfiguration.java +++ b/src/main/java/com/mycompany/myapp/config/CacheConfiguration.java @@ -40,6 +40,11 @@ public JCacheManagerCustomizer cacheManagerCustomizer() { createCache(cm, com.mycompany.myapp.domain.User.class.getName()); createCache(cm, com.mycompany.myapp.domain.Authority.class.getName()); createCache(cm, com.mycompany.myapp.domain.User.class.getName() + ".authorities"); + createCache(cm, com.mycompany.myapp.domain.GameUser.class.getName()); + createCache(cm, com.mycompany.myapp.domain.GameUser.class.getName() + ".commissions"); + createCache(cm, com.mycompany.myapp.domain.GameCommission.class.getName()); + createCache(cm, com.mycompany.myapp.domain.Game.class.getName()); + createCache(cm, com.mycompany.myapp.domain.Game.class.getName() + ".gameCommissions"); // jhipster-needle-ehcache-add-entry }; } diff --git a/src/main/java/com/mycompany/myapp/domain/Game.java b/src/main/java/com/mycompany/myapp/domain/Game.java new file mode 100644 index 0000000..81bd949 --- /dev/null +++ b/src/main/java/com/mycompany/myapp/domain/Game.java @@ -0,0 +1,105 @@ +package com.mycompany.myapp.domain; + +import org.hibernate.annotations.Cache; +import org.hibernate.annotations.CacheConcurrencyStrategy; + +import javax.persistence.*; + +import java.io.Serializable; +import java.util.Objects; +import java.util.HashSet; +import java.util.Set; + +/** + * A Game. + */ +@Entity +@Table(name = "game") +@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) +public class Game implements Serializable { + + private static final long serialVersionUID = 1L; + + @Id + @GeneratedValue(strategy = GenerationType.IDENTITY) + private Long id; + + @Column(name = "name") + private String name; + + @OneToMany(mappedBy = "game") + @Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) + private Set gameCommissions = new HashSet<>(); + + // jhipster-needle-entity-add-field - JHipster will add fields here, do not remove + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getName() { + return name; + } + + public Game name(String name) { + this.name = name; + return this; + } + + public void setName(String name) { + this.name = name; + } + + public Set getGameCommissions() { + return gameCommissions; + } + + public Game gameCommissions(Set gameCommissions) { + this.gameCommissions = gameCommissions; + return this; + } + + public Game addGameCommission(GameCommission gameCommission) { + this.gameCommissions.add(gameCommission); + gameCommission.setGame(this); + return this; + } + + public Game removeGameCommission(GameCommission gameCommission) { + this.gameCommissions.remove(gameCommission); + gameCommission.setGame(null); + return this; + } + + public void setGameCommissions(Set gameCommissions) { + this.gameCommissions = gameCommissions; + } + // jhipster-needle-entity-add-getters-setters - JHipster will add getters and setters here, do not remove + + @Override + public boolean equals(Object o) { + if (this == o) { + return true; + } + if (!(o instanceof Game)) { + return false; + } + return id != null && id.equals(((Game) o).id); + } + + @Override + public int hashCode() { + return 31; + } + + @Override + public String toString() { + return "Game{" + + "id=" + getId() + + ", name='" + getName() + "'" + + "}"; + } +} diff --git a/src/main/java/com/mycompany/myapp/domain/GameCommission.java b/src/main/java/com/mycompany/myapp/domain/GameCommission.java new file mode 100644 index 0000000..b412c32 --- /dev/null +++ b/src/main/java/com/mycompany/myapp/domain/GameCommission.java @@ -0,0 +1,109 @@ +package com.mycompany.myapp.domain; + +import com.fasterxml.jackson.annotation.JsonIgnoreProperties; +import org.hibernate.annotations.Cache; +import org.hibernate.annotations.CacheConcurrencyStrategy; + +import javax.persistence.*; + +import java.io.Serializable; +import java.util.Objects; + +/** + * A GameCommission. + */ +@Entity +@Table(name = "game_commission") +@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) +public class GameCommission implements Serializable { + + private static final long serialVersionUID = 1L; + + @Id + @GeneratedValue(strategy = GenerationType.IDENTITY) + private Long id; + + @Column(name = "commission") + private Integer commission; + + @ManyToOne + @JsonIgnoreProperties("commissions") + private GameUser gameUser; + + @ManyToOne + @JsonIgnoreProperties("gameCommissions") + private Game game; + + // jhipster-needle-entity-add-field - JHipster will add fields here, do not remove + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public Integer getCommission() { + return commission; + } + + public GameCommission commission(Integer commission) { + this.commission = commission; + return this; + } + + public void setCommission(Integer commission) { + this.commission = commission; + } + + public GameUser getGameUser() { + return gameUser; + } + + public GameCommission gameUser(GameUser gameUser) { + this.gameUser = gameUser; + return this; + } + + public void setGameUser(GameUser gameUser) { + this.gameUser = gameUser; + } + + public Game getGame() { + return game; + } + + public GameCommission game(Game game) { + this.game = game; + return this; + } + + public void setGame(Game game) { + this.game = game; + } + // jhipster-needle-entity-add-getters-setters - JHipster will add getters and setters here, do not remove + + @Override + public boolean equals(Object o) { + if (this == o) { + return true; + } + if (!(o instanceof GameCommission)) { + return false; + } + return id != null && id.equals(((GameCommission) o).id); + } + + @Override + public int hashCode() { + return 31; + } + + @Override + public String toString() { + return "GameCommission{" + + "id=" + getId() + + ", commission=" + getCommission() + + "}"; + } +} diff --git a/src/main/java/com/mycompany/myapp/domain/GameUser.java b/src/main/java/com/mycompany/myapp/domain/GameUser.java new file mode 100644 index 0000000..6931d12 --- /dev/null +++ b/src/main/java/com/mycompany/myapp/domain/GameUser.java @@ -0,0 +1,122 @@ +package com.mycompany.myapp.domain; + +import org.hibernate.annotations.Cache; +import org.hibernate.annotations.CacheConcurrencyStrategy; + +import javax.persistence.*; + +import java.io.Serializable; +import java.util.Objects; +import java.util.HashSet; +import java.util.Set; + +/** + * A GameUser. + */ +@Entity +@Table(name = "game_user") +@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) +public class GameUser implements Serializable { + + private static final long serialVersionUID = 1L; + + @Id + @GeneratedValue(strategy = GenerationType.IDENTITY) + private Long id; + + @Column(name = "username") + private String username; + + @Column(name = "password") + private String password; + + @OneToMany(mappedBy = "gameUser") + @Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE) + private Set commissions = new HashSet<>(); + + // jhipster-needle-entity-add-field - JHipster will add fields here, do not remove + public Long getId() { + return id; + } + + public void setId(Long id) { + this.id = id; + } + + public String getUsername() { + return username; + } + + public GameUser username(String username) { + this.username = username; + return this; + } + + public void setUsername(String username) { + this.username = username; + } + + public String getPassword() { + return password; + } + + public GameUser password(String password) { + this.password = password; + return this; + } + + public void setPassword(String password) { + this.password = password; + } + + public Set getCommissions() { + return commissions; + } + + public GameUser commissions(Set gameCommissions) { + this.commissions = gameCommissions; + return this; + } + + public GameUser addCommission(GameCommission gameCommission) { + this.commissions.add(gameCommission); + gameCommission.setGameUser(this); + return this; + } + + public GameUser removeCommission(GameCommission gameCommission) { + this.commissions.remove(gameCommission); + gameCommission.setGameUser(null); + return this; + } + + public void setCommissions(Set gameCommissions) { + this.commissions = gameCommissions; + } + // jhipster-needle-entity-add-getters-setters - JHipster will add getters and setters here, do not remove + + @Override + public boolean equals(Object o) { + if (this == o) { + return true; + } + if (!(o instanceof GameUser)) { + return false; + } + return id != null && id.equals(((GameUser) o).id); + } + + @Override + public int hashCode() { + return 31; + } + + @Override + public String toString() { + return "GameUser{" + + "id=" + getId() + + ", username='" + getUsername() + "'" + + ", password='" + getPassword() + "'" + + "}"; + } +} diff --git a/src/main/java/com/mycompany/myapp/repository/GameCommissionRepository.java b/src/main/java/com/mycompany/myapp/repository/GameCommissionRepository.java new file mode 100644 index 0000000..4492fff --- /dev/null +++ b/src/main/java/com/mycompany/myapp/repository/GameCommissionRepository.java @@ -0,0 +1,14 @@ +package com.mycompany.myapp.repository; + +import com.mycompany.myapp.domain.GameCommission; + +import org.springframework.data.jpa.repository.*; +import org.springframework.stereotype.Repository; + +/** + * Spring Data repository for the GameCommission entity. + */ +@SuppressWarnings("unused") +@Repository +public interface GameCommissionRepository extends JpaRepository { +} diff --git a/src/main/java/com/mycompany/myapp/repository/GameRepository.java b/src/main/java/com/mycompany/myapp/repository/GameRepository.java new file mode 100644 index 0000000..d429520 --- /dev/null +++ b/src/main/java/com/mycompany/myapp/repository/GameRepository.java @@ -0,0 +1,14 @@ +package com.mycompany.myapp.repository; + +import com.mycompany.myapp.domain.Game; + +import org.springframework.data.jpa.repository.*; +import org.springframework.stereotype.Repository; + +/** + * Spring Data repository for the Game entity. + */ +@SuppressWarnings("unused") +@Repository +public interface GameRepository extends JpaRepository { +} diff --git a/src/main/java/com/mycompany/myapp/repository/GameUserRepository.java b/src/main/java/com/mycompany/myapp/repository/GameUserRepository.java new file mode 100644 index 0000000..ebb8302 --- /dev/null +++ b/src/main/java/com/mycompany/myapp/repository/GameUserRepository.java @@ -0,0 +1,14 @@ +package com.mycompany.myapp.repository; + +import com.mycompany.myapp.domain.GameUser; + +import org.springframework.data.jpa.repository.*; +import org.springframework.stereotype.Repository; + +/** + * Spring Data repository for the GameUser entity. + */ +@SuppressWarnings("unused") +@Repository +public interface GameUserRepository extends JpaRepository { +} diff --git a/src/main/java/com/mycompany/myapp/web/rest/GameCommissionResource.java b/src/main/java/com/mycompany/myapp/web/rest/GameCommissionResource.java new file mode 100644 index 0000000..6def2ef --- /dev/null +++ b/src/main/java/com/mycompany/myapp/web/rest/GameCommissionResource.java @@ -0,0 +1,118 @@ +package com.mycompany.myapp.web.rest; + +import com.mycompany.myapp.domain.GameCommission; +import com.mycompany.myapp.repository.GameCommissionRepository; +import com.mycompany.myapp.web.rest.errors.BadRequestAlertException; + +import io.github.jhipster.web.util.HeaderUtil; +import io.github.jhipster.web.util.ResponseUtil; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.http.ResponseEntity; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.web.bind.annotation.*; + +import java.net.URI; +import java.net.URISyntaxException; +import java.util.List; +import java.util.Optional; + +/** + * REST controller for managing {@link com.mycompany.myapp.domain.GameCommission}. + */ +@RestController +@RequestMapping("/api") +@Transactional +public class GameCommissionResource { + + private final Logger log = LoggerFactory.getLogger(GameCommissionResource.class); + + private static final String ENTITY_NAME = "gameCommission"; + + @Value("${jhipster.clientApp.name}") + private String applicationName; + + private final GameCommissionRepository gameCommissionRepository; + + public GameCommissionResource(GameCommissionRepository gameCommissionRepository) { + this.gameCommissionRepository = gameCommissionRepository; + } + + /** + * {@code POST /game-commissions} : Create a new gameCommission. + * + * @param gameCommission the gameCommission to create. + * @return the {@link ResponseEntity} with status {@code 201 (Created)} and with body the new gameCommission, or with status {@code 400 (Bad Request)} if the gameCommission has already an ID. + * @throws URISyntaxException if the Location URI syntax is incorrect. + */ + @PostMapping("/game-commissions") + public ResponseEntity createGameCommission(@RequestBody GameCommission gameCommission) throws URISyntaxException { + log.debug("REST request to save GameCommission : {}", gameCommission); + if (gameCommission.getId() != null) { + throw new BadRequestAlertException("A new gameCommission cannot already have an ID", ENTITY_NAME, "idexists"); + } + GameCommission result = gameCommissionRepository.save(gameCommission); + return ResponseEntity.created(new URI("/api/game-commissions/" + result.getId())) + .headers(HeaderUtil.createEntityCreationAlert(applicationName, false, ENTITY_NAME, result.getId().toString())) + .body(result); + } + + /** + * {@code PUT /game-commissions} : Updates an existing gameCommission. + * + * @param gameCommission the gameCommission to update. + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and with body the updated gameCommission, + * or with status {@code 400 (Bad Request)} if the gameCommission is not valid, + * or with status {@code 500 (Internal Server Error)} if the gameCommission couldn't be updated. + * @throws URISyntaxException if the Location URI syntax is incorrect. + */ + @PutMapping("/game-commissions") + public ResponseEntity updateGameCommission(@RequestBody GameCommission gameCommission) throws URISyntaxException { + log.debug("REST request to update GameCommission : {}", gameCommission); + if (gameCommission.getId() == null) { + throw new BadRequestAlertException("Invalid id", ENTITY_NAME, "idnull"); + } + GameCommission result = gameCommissionRepository.save(gameCommission); + return ResponseEntity.ok() + .headers(HeaderUtil.createEntityUpdateAlert(applicationName, false, ENTITY_NAME, gameCommission.getId().toString())) + .body(result); + } + + /** + * {@code GET /game-commissions} : get all the gameCommissions. + * + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and the list of gameCommissions in body. + */ + @GetMapping("/game-commissions") + public List getAllGameCommissions() { + log.debug("REST request to get all GameCommissions"); + return gameCommissionRepository.findAll(); + } + + /** + * {@code GET /game-commissions/:id} : get the "id" gameCommission. + * + * @param id the id of the gameCommission to retrieve. + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and with body the gameCommission, or with status {@code 404 (Not Found)}. + */ + @GetMapping("/game-commissions/{id}") + public ResponseEntity getGameCommission(@PathVariable Long id) { + log.debug("REST request to get GameCommission : {}", id); + Optional gameCommission = gameCommissionRepository.findById(id); + return ResponseUtil.wrapOrNotFound(gameCommission); + } + + /** + * {@code DELETE /game-commissions/:id} : delete the "id" gameCommission. + * + * @param id the id of the gameCommission to delete. + * @return the {@link ResponseEntity} with status {@code 204 (NO_CONTENT)}. + */ + @DeleteMapping("/game-commissions/{id}") + public ResponseEntity deleteGameCommission(@PathVariable Long id) { + log.debug("REST request to delete GameCommission : {}", id); + gameCommissionRepository.deleteById(id); + return ResponseEntity.noContent().headers(HeaderUtil.createEntityDeletionAlert(applicationName, false, ENTITY_NAME, id.toString())).build(); + } +} diff --git a/src/main/java/com/mycompany/myapp/web/rest/GameResource.java b/src/main/java/com/mycompany/myapp/web/rest/GameResource.java new file mode 100644 index 0000000..5d63a02 --- /dev/null +++ b/src/main/java/com/mycompany/myapp/web/rest/GameResource.java @@ -0,0 +1,118 @@ +package com.mycompany.myapp.web.rest; + +import com.mycompany.myapp.domain.Game; +import com.mycompany.myapp.repository.GameRepository; +import com.mycompany.myapp.web.rest.errors.BadRequestAlertException; + +import io.github.jhipster.web.util.HeaderUtil; +import io.github.jhipster.web.util.ResponseUtil; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.http.ResponseEntity; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.web.bind.annotation.*; + +import java.net.URI; +import java.net.URISyntaxException; +import java.util.List; +import java.util.Optional; + +/** + * REST controller for managing {@link com.mycompany.myapp.domain.Game}. + */ +@RestController +@RequestMapping("/api") +@Transactional +public class GameResource { + + private final Logger log = LoggerFactory.getLogger(GameResource.class); + + private static final String ENTITY_NAME = "game"; + + @Value("${jhipster.clientApp.name}") + private String applicationName; + + private final GameRepository gameRepository; + + public GameResource(GameRepository gameRepository) { + this.gameRepository = gameRepository; + } + + /** + * {@code POST /games} : Create a new game. + * + * @param game the game to create. + * @return the {@link ResponseEntity} with status {@code 201 (Created)} and with body the new game, or with status {@code 400 (Bad Request)} if the game has already an ID. + * @throws URISyntaxException if the Location URI syntax is incorrect. + */ + @PostMapping("/games") + public ResponseEntity createGame(@RequestBody Game game) throws URISyntaxException { + log.debug("REST request to save Game : {}", game); + if (game.getId() != null) { + throw new BadRequestAlertException("A new game cannot already have an ID", ENTITY_NAME, "idexists"); + } + Game result = gameRepository.save(game); + return ResponseEntity.created(new URI("/api/games/" + result.getId())) + .headers(HeaderUtil.createEntityCreationAlert(applicationName, false, ENTITY_NAME, result.getId().toString())) + .body(result); + } + + /** + * {@code PUT /games} : Updates an existing game. + * + * @param game the game to update. + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and with body the updated game, + * or with status {@code 400 (Bad Request)} if the game is not valid, + * or with status {@code 500 (Internal Server Error)} if the game couldn't be updated. + * @throws URISyntaxException if the Location URI syntax is incorrect. + */ + @PutMapping("/games") + public ResponseEntity updateGame(@RequestBody Game game) throws URISyntaxException { + log.debug("REST request to update Game : {}", game); + if (game.getId() == null) { + throw new BadRequestAlertException("Invalid id", ENTITY_NAME, "idnull"); + } + Game result = gameRepository.save(game); + return ResponseEntity.ok() + .headers(HeaderUtil.createEntityUpdateAlert(applicationName, false, ENTITY_NAME, game.getId().toString())) + .body(result); + } + + /** + * {@code GET /games} : get all the games. + * + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and the list of games in body. + */ + @GetMapping("/games") + public List getAllGames() { + log.debug("REST request to get all Games"); + return gameRepository.findAll(); + } + + /** + * {@code GET /games/:id} : get the "id" game. + * + * @param id the id of the game to retrieve. + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and with body the game, or with status {@code 404 (Not Found)}. + */ + @GetMapping("/games/{id}") + public ResponseEntity getGame(@PathVariable Long id) { + log.debug("REST request to get Game : {}", id); + Optional game = gameRepository.findById(id); + return ResponseUtil.wrapOrNotFound(game); + } + + /** + * {@code DELETE /games/:id} : delete the "id" game. + * + * @param id the id of the game to delete. + * @return the {@link ResponseEntity} with status {@code 204 (NO_CONTENT)}. + */ + @DeleteMapping("/games/{id}") + public ResponseEntity deleteGame(@PathVariable Long id) { + log.debug("REST request to delete Game : {}", id); + gameRepository.deleteById(id); + return ResponseEntity.noContent().headers(HeaderUtil.createEntityDeletionAlert(applicationName, false, ENTITY_NAME, id.toString())).build(); + } +} diff --git a/src/main/java/com/mycompany/myapp/web/rest/GameUserResource.java b/src/main/java/com/mycompany/myapp/web/rest/GameUserResource.java new file mode 100644 index 0000000..f06907e --- /dev/null +++ b/src/main/java/com/mycompany/myapp/web/rest/GameUserResource.java @@ -0,0 +1,118 @@ +package com.mycompany.myapp.web.rest; + +import com.mycompany.myapp.domain.GameUser; +import com.mycompany.myapp.repository.GameUserRepository; +import com.mycompany.myapp.web.rest.errors.BadRequestAlertException; + +import io.github.jhipster.web.util.HeaderUtil; +import io.github.jhipster.web.util.ResponseUtil; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.http.ResponseEntity; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.web.bind.annotation.*; + +import java.net.URI; +import java.net.URISyntaxException; +import java.util.List; +import java.util.Optional; + +/** + * REST controller for managing {@link com.mycompany.myapp.domain.GameUser}. + */ +@RestController +@RequestMapping("/api") +@Transactional +public class GameUserResource { + + private final Logger log = LoggerFactory.getLogger(GameUserResource.class); + + private static final String ENTITY_NAME = "gameUser"; + + @Value("${jhipster.clientApp.name}") + private String applicationName; + + private final GameUserRepository gameUserRepository; + + public GameUserResource(GameUserRepository gameUserRepository) { + this.gameUserRepository = gameUserRepository; + } + + /** + * {@code POST /game-users} : Create a new gameUser. + * + * @param gameUser the gameUser to create. + * @return the {@link ResponseEntity} with status {@code 201 (Created)} and with body the new gameUser, or with status {@code 400 (Bad Request)} if the gameUser has already an ID. + * @throws URISyntaxException if the Location URI syntax is incorrect. + */ + @PostMapping("/game-users") + public ResponseEntity createGameUser(@RequestBody GameUser gameUser) throws URISyntaxException { + log.debug("REST request to save GameUser : {}", gameUser); + if (gameUser.getId() != null) { + throw new BadRequestAlertException("A new gameUser cannot already have an ID", ENTITY_NAME, "idexists"); + } + GameUser result = gameUserRepository.save(gameUser); + return ResponseEntity.created(new URI("/api/game-users/" + result.getId())) + .headers(HeaderUtil.createEntityCreationAlert(applicationName, false, ENTITY_NAME, result.getId().toString())) + .body(result); + } + + /** + * {@code PUT /game-users} : Updates an existing gameUser. + * + * @param gameUser the gameUser to update. + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and with body the updated gameUser, + * or with status {@code 400 (Bad Request)} if the gameUser is not valid, + * or with status {@code 500 (Internal Server Error)} if the gameUser couldn't be updated. + * @throws URISyntaxException if the Location URI syntax is incorrect. + */ + @PutMapping("/game-users") + public ResponseEntity updateGameUser(@RequestBody GameUser gameUser) throws URISyntaxException { + log.debug("REST request to update GameUser : {}", gameUser); + if (gameUser.getId() == null) { + throw new BadRequestAlertException("Invalid id", ENTITY_NAME, "idnull"); + } + GameUser result = gameUserRepository.save(gameUser); + return ResponseEntity.ok() + .headers(HeaderUtil.createEntityUpdateAlert(applicationName, false, ENTITY_NAME, gameUser.getId().toString())) + .body(result); + } + + /** + * {@code GET /game-users} : get all the gameUsers. + * + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and the list of gameUsers in body. + */ + @GetMapping("/game-users") + public List getAllGameUsers() { + log.debug("REST request to get all GameUsers"); + return gameUserRepository.findAll(); + } + + /** + * {@code GET /game-users/:id} : get the "id" gameUser. + * + * @param id the id of the gameUser to retrieve. + * @return the {@link ResponseEntity} with status {@code 200 (OK)} and with body the gameUser, or with status {@code 404 (Not Found)}. + */ + @GetMapping("/game-users/{id}") + public ResponseEntity getGameUser(@PathVariable Long id) { + log.debug("REST request to get GameUser : {}", id); + Optional gameUser = gameUserRepository.findById(id); + return ResponseUtil.wrapOrNotFound(gameUser); + } + + /** + * {@code DELETE /game-users/:id} : delete the "id" gameUser. + * + * @param id the id of the gameUser to delete. + * @return the {@link ResponseEntity} with status {@code 204 (NO_CONTENT)}. + */ + @DeleteMapping("/game-users/{id}") + public ResponseEntity deleteGameUser(@PathVariable Long id) { + log.debug("REST request to delete GameUser : {}", id); + gameUserRepository.deleteById(id); + return ResponseEntity.noContent().headers(HeaderUtil.createEntityDeletionAlert(applicationName, false, ENTITY_NAME, id.toString())).build(); + } +} diff --git a/src/main/resources/config/liquibase/changelog/20200328164100_added_entity_GameUser.xml b/src/main/resources/config/liquibase/changelog/20200328164100_added_entity_GameUser.xml new file mode 100644 index 0000000..699dd5a --- /dev/null +++ b/src/main/resources/config/liquibase/changelog/20200328164100_added_entity_GameUser.xml @@ -0,0 +1,54 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/main/resources/config/liquibase/changelog/20200328164200_added_entity_GameCommission.xml b/src/main/resources/config/liquibase/changelog/20200328164200_added_entity_GameCommission.xml new file mode 100644 index 0000000..b75c9b8 --- /dev/null +++ b/src/main/resources/config/liquibase/changelog/20200328164200_added_entity_GameCommission.xml @@ -0,0 +1,56 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/main/resources/config/liquibase/changelog/20200328164200_added_entity_constraints_GameCommission.xml b/src/main/resources/config/liquibase/changelog/20200328164200_added_entity_constraints_GameCommission.xml new file mode 100644 index 0000000..c662077 --- /dev/null +++ b/src/main/resources/config/liquibase/changelog/20200328164200_added_entity_constraints_GameCommission.xml @@ -0,0 +1,24 @@ + + + + + + + + + + + diff --git a/src/main/resources/config/liquibase/changelog/20200328164300_added_entity_Game.xml b/src/main/resources/config/liquibase/changelog/20200328164300_added_entity_Game.xml new file mode 100644 index 0000000..74ae61a --- /dev/null +++ b/src/main/resources/config/liquibase/changelog/20200328164300_added_entity_Game.xml @@ -0,0 +1,50 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/main/resources/config/liquibase/fake-data/game.csv b/src/main/resources/config/liquibase/fake-data/game.csv new file mode 100644 index 0000000..a6d440f --- /dev/null +++ b/src/main/resources/config/liquibase/fake-data/game.csv @@ -0,0 +1,11 @@ +id;name +1;override calculate connect +2;Dynamic Creative vortals +3;TCP streamline 4th generation +4;bottom-line user-facing Bike +5;Tasty Rubber Fish Borders +6;mint green Marketing Montana +7;JBOD Ghana Niue +8;even-keeled invoice JSON +9;Lock models +10;orchid Cambridgeshire diff --git a/src/main/resources/config/liquibase/fake-data/game_commission.csv b/src/main/resources/config/liquibase/fake-data/game_commission.csv new file mode 100644 index 0000000..110e9c6 --- /dev/null +++ b/src/main/resources/config/liquibase/fake-data/game_commission.csv @@ -0,0 +1,11 @@ +id;commission +1;87478 +2;49175 +3;81846 +4;72354 +5;3005 +6;64675 +7;92359 +8;92285 +9;71424 +10;85739 diff --git a/src/main/resources/config/liquibase/fake-data/game_user.csv b/src/main/resources/config/liquibase/fake-data/game_user.csv new file mode 100644 index 0000000..bd9d860 --- /dev/null +++ b/src/main/resources/config/liquibase/fake-data/game_user.csv @@ -0,0 +1,11 @@ +id;username;password +1;input Square Maryland;vortals Gorgeous indigo +2;niches asynchronous Games;actuating Group +3;Synergistic Managed;Uganda Shilling +4;Director architecture;deposit +5;interfaces Personal Loan Account;invoice Specialist Devolved +6;Plains Paradigm Generic;Libyan Dinar Handmade +7;calculating Cambridgeshire Digitized;application Belarus +8;yellow Rubber seize;leverage Money Market Account hack +9;Cheese;payment South Carolina Checking Account +10;compress;leading-edge Latvian Lats diff --git a/src/main/resources/config/liquibase/master.xml b/src/main/resources/config/liquibase/master.xml index 2ddb55e..32f39dd 100644 --- a/src/main/resources/config/liquibase/master.xml +++ b/src/main/resources/config/liquibase/master.xml @@ -14,6 +14,10 @@ + + + + diff --git a/src/main/webapp/app/entities/entity.module.ts b/src/main/webapp/app/entities/entity.module.ts index 12af520..325c44b 100644 --- a/src/main/webapp/app/entities/entity.module.ts +++ b/src/main/webapp/app/entities/entity.module.ts @@ -4,6 +4,18 @@ import { RouterModule } from '@angular/router'; @NgModule({ imports: [ RouterModule.forChild([ + { + path: 'game-user', + loadChildren: () => import('./game-user/game-user.module').then(m => m.AdminGameUserModule) + }, + { + path: 'game-commission', + loadChildren: () => import('./game-commission/game-commission.module').then(m => m.AdminGameCommissionModule) + }, + { + path: 'game', + loadChildren: () => import('./game/game.module').then(m => m.AdminGameModule) + } /* jhipster-needle-add-entity-route - JHipster will add entity modules routes here */ ]) ] diff --git a/src/main/webapp/app/entities/game-commission/game-commission-delete-dialog.component.html b/src/main/webapp/app/entities/game-commission/game-commission-delete-dialog.component.html new file mode 100644 index 0000000..f7c7732 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission-delete-dialog.component.html @@ -0,0 +1,24 @@ +
+ + + + + +
diff --git a/src/main/webapp/app/entities/game-commission/game-commission-delete-dialog.component.ts b/src/main/webapp/app/entities/game-commission/game-commission-delete-dialog.component.ts new file mode 100644 index 0000000..b161baa --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission-delete-dialog.component.ts @@ -0,0 +1,30 @@ +import { Component } from '@angular/core'; +import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap'; +import { JhiEventManager } from 'ng-jhipster'; + +import { IGameCommission } from 'app/shared/model/game-commission.model'; +import { GameCommissionService } from './game-commission.service'; + +@Component({ + templateUrl: './game-commission-delete-dialog.component.html' +}) +export class GameCommissionDeleteDialogComponent { + gameCommission?: IGameCommission; + + constructor( + protected gameCommissionService: GameCommissionService, + public activeModal: NgbActiveModal, + protected eventManager: JhiEventManager + ) {} + + cancel(): void { + this.activeModal.dismiss(); + } + + confirmDelete(id: number): void { + this.gameCommissionService.delete(id).subscribe(() => { + this.eventManager.broadcast('gameCommissionListModification'); + this.activeModal.close(); + }); + } +} diff --git a/src/main/webapp/app/entities/game-commission/game-commission-detail.component.html b/src/main/webapp/app/entities/game-commission/game-commission-detail.component.html new file mode 100644 index 0000000..8704c06 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission-detail.component.html @@ -0,0 +1,42 @@ +
+
+
+

Game Commission {{ gameCommission.id }}

+ +
+ + + +
+
Commission
+
+ {{ gameCommission.commission }} +
+
Game User
+
+ +
+
Game
+
+ +
+
+ + + + +
+
+
diff --git a/src/main/webapp/app/entities/game-commission/game-commission-detail.component.ts b/src/main/webapp/app/entities/game-commission/game-commission-detail.component.ts new file mode 100644 index 0000000..c418393 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission-detail.component.ts @@ -0,0 +1,22 @@ +import { Component, OnInit } from '@angular/core'; +import { ActivatedRoute } from '@angular/router'; + +import { IGameCommission } from 'app/shared/model/game-commission.model'; + +@Component({ + selector: 'jhi-game-commission-detail', + templateUrl: './game-commission-detail.component.html' +}) +export class GameCommissionDetailComponent implements OnInit { + gameCommission: IGameCommission | null = null; + + constructor(protected activatedRoute: ActivatedRoute) {} + + ngOnInit(): void { + this.activatedRoute.data.subscribe(({ gameCommission }) => (this.gameCommission = gameCommission)); + } + + previousState(): void { + window.history.back(); + } +} diff --git a/src/main/webapp/app/entities/game-commission/game-commission-update.component.html b/src/main/webapp/app/entities/game-commission/game-commission-update.component.html new file mode 100644 index 0000000..027d146 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission-update.component.html @@ -0,0 +1,48 @@ +
+
+
+

Create or edit a Game Commission

+ +
+ + +
+ + +
+ +
+ + +
+ +
+ + +
+ +
+ + +
+
+ +
+ + + +
+
+
+
diff --git a/src/main/webapp/app/entities/game-commission/game-commission-update.component.ts b/src/main/webapp/app/entities/game-commission/game-commission-update.component.ts new file mode 100644 index 0000000..d4d00ed --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission-update.component.ts @@ -0,0 +1,103 @@ +import { Component, OnInit } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +// eslint-disable-next-line @typescript-eslint/no-unused-vars +import { FormBuilder, Validators } from '@angular/forms'; +import { ActivatedRoute } from '@angular/router'; +import { Observable } from 'rxjs'; + +import { IGameCommission, GameCommission } from 'app/shared/model/game-commission.model'; +import { GameCommissionService } from './game-commission.service'; +import { IGameUser } from 'app/shared/model/game-user.model'; +import { GameUserService } from 'app/entities/game-user/game-user.service'; +import { IGame } from 'app/shared/model/game.model'; +import { GameService } from 'app/entities/game/game.service'; + +type SelectableEntity = IGameUser | IGame; + +@Component({ + selector: 'jhi-game-commission-update', + templateUrl: './game-commission-update.component.html' +}) +export class GameCommissionUpdateComponent implements OnInit { + isSaving = false; + gameusers: IGameUser[] = []; + games: IGame[] = []; + + editForm = this.fb.group({ + id: [], + commission: [], + gameUser: [], + game: [] + }); + + constructor( + protected gameCommissionService: GameCommissionService, + protected gameUserService: GameUserService, + protected gameService: GameService, + protected activatedRoute: ActivatedRoute, + private fb: FormBuilder + ) {} + + ngOnInit(): void { + this.activatedRoute.data.subscribe(({ gameCommission }) => { + this.updateForm(gameCommission); + + this.gameUserService.query().subscribe((res: HttpResponse) => (this.gameusers = res.body || [])); + + this.gameService.query().subscribe((res: HttpResponse) => (this.games = res.body || [])); + }); + } + + updateForm(gameCommission: IGameCommission): void { + this.editForm.patchValue({ + id: gameCommission.id, + commission: gameCommission.commission, + gameUser: gameCommission.gameUser, + game: gameCommission.game + }); + } + + previousState(): void { + window.history.back(); + } + + save(): void { + this.isSaving = true; + const gameCommission = this.createFromForm(); + if (gameCommission.id !== undefined) { + this.subscribeToSaveResponse(this.gameCommissionService.update(gameCommission)); + } else { + this.subscribeToSaveResponse(this.gameCommissionService.create(gameCommission)); + } + } + + private createFromForm(): IGameCommission { + return { + ...new GameCommission(), + id: this.editForm.get(['id'])!.value, + commission: this.editForm.get(['commission'])!.value, + gameUser: this.editForm.get(['gameUser'])!.value, + game: this.editForm.get(['game'])!.value + }; + } + + protected subscribeToSaveResponse(result: Observable>): void { + result.subscribe( + () => this.onSaveSuccess(), + () => this.onSaveError() + ); + } + + protected onSaveSuccess(): void { + this.isSaving = false; + this.previousState(); + } + + protected onSaveError(): void { + this.isSaving = false; + } + + trackById(index: number, item: SelectableEntity): any { + return item.id; + } +} diff --git a/src/main/webapp/app/entities/game-commission/game-commission.component.html b/src/main/webapp/app/entities/game-commission/game-commission.component.html new file mode 100644 index 0000000..a80ae61 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission.component.html @@ -0,0 +1,73 @@ +
+

+ Game Commissions + + +

+ + + + + +
+ No gameCommissions found +
+ +
+ + + + + + + + + + + + + + + + + + + +
IDCommissionGame UserGame
{{ gameCommission.id }}{{ gameCommission.commission }} + + + + +
+ + + + + +
+
+
+
diff --git a/src/main/webapp/app/entities/game-commission/game-commission.component.ts b/src/main/webapp/app/entities/game-commission/game-commission.component.ts new file mode 100644 index 0000000..e4612c3 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission.component.ts @@ -0,0 +1,53 @@ +import { Component, OnInit, OnDestroy } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +import { Subscription } from 'rxjs'; +import { JhiEventManager } from 'ng-jhipster'; +import { NgbModal } from '@ng-bootstrap/ng-bootstrap'; + +import { IGameCommission } from 'app/shared/model/game-commission.model'; +import { GameCommissionService } from './game-commission.service'; +import { GameCommissionDeleteDialogComponent } from './game-commission-delete-dialog.component'; + +@Component({ + selector: 'jhi-game-commission', + templateUrl: './game-commission.component.html' +}) +export class GameCommissionComponent implements OnInit, OnDestroy { + gameCommissions?: IGameCommission[]; + eventSubscriber?: Subscription; + + constructor( + protected gameCommissionService: GameCommissionService, + protected eventManager: JhiEventManager, + protected modalService: NgbModal + ) {} + + loadAll(): void { + this.gameCommissionService.query().subscribe((res: HttpResponse) => (this.gameCommissions = res.body || [])); + } + + ngOnInit(): void { + this.loadAll(); + this.registerChangeInGameCommissions(); + } + + ngOnDestroy(): void { + if (this.eventSubscriber) { + this.eventManager.destroy(this.eventSubscriber); + } + } + + trackId(index: number, item: IGameCommission): number { + // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion + return item.id!; + } + + registerChangeInGameCommissions(): void { + this.eventSubscriber = this.eventManager.subscribe('gameCommissionListModification', () => this.loadAll()); + } + + delete(gameCommission: IGameCommission): void { + const modalRef = this.modalService.open(GameCommissionDeleteDialogComponent, { size: 'lg', backdrop: 'static' }); + modalRef.componentInstance.gameCommission = gameCommission; + } +} diff --git a/src/main/webapp/app/entities/game-commission/game-commission.module.ts b/src/main/webapp/app/entities/game-commission/game-commission.module.ts new file mode 100644 index 0000000..ba35609 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission.module.ts @@ -0,0 +1,21 @@ +import { NgModule } from '@angular/core'; +import { RouterModule } from '@angular/router'; + +import { AdminSharedModule } from 'app/shared/shared.module'; +import { GameCommissionComponent } from './game-commission.component'; +import { GameCommissionDetailComponent } from './game-commission-detail.component'; +import { GameCommissionUpdateComponent } from './game-commission-update.component'; +import { GameCommissionDeleteDialogComponent } from './game-commission-delete-dialog.component'; +import { gameCommissionRoute } from './game-commission.route'; + +@NgModule({ + imports: [AdminSharedModule, RouterModule.forChild(gameCommissionRoute)], + declarations: [ + GameCommissionComponent, + GameCommissionDetailComponent, + GameCommissionUpdateComponent, + GameCommissionDeleteDialogComponent + ], + entryComponents: [GameCommissionDeleteDialogComponent] +}) +export class AdminGameCommissionModule {} diff --git a/src/main/webapp/app/entities/game-commission/game-commission.route.ts b/src/main/webapp/app/entities/game-commission/game-commission.route.ts new file mode 100644 index 0000000..a3878da --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission.route.ts @@ -0,0 +1,83 @@ +import { Injectable } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +import { Resolve, ActivatedRouteSnapshot, Routes, Router } from '@angular/router'; +import { Observable, of, EMPTY } from 'rxjs'; +import { flatMap } from 'rxjs/operators'; + +import { Authority } from 'app/shared/constants/authority.constants'; +import { UserRouteAccessService } from 'app/core/auth/user-route-access-service'; +import { IGameCommission, GameCommission } from 'app/shared/model/game-commission.model'; +import { GameCommissionService } from './game-commission.service'; +import { GameCommissionComponent } from './game-commission.component'; +import { GameCommissionDetailComponent } from './game-commission-detail.component'; +import { GameCommissionUpdateComponent } from './game-commission-update.component'; + +@Injectable({ providedIn: 'root' }) +export class GameCommissionResolve implements Resolve { + constructor(private service: GameCommissionService, private router: Router) {} + + resolve(route: ActivatedRouteSnapshot): Observable | Observable { + const id = route.params['id']; + if (id) { + return this.service.find(id).pipe( + flatMap((gameCommission: HttpResponse) => { + if (gameCommission.body) { + return of(gameCommission.body); + } else { + this.router.navigate(['404']); + return EMPTY; + } + }) + ); + } + return of(new GameCommission()); + } +} + +export const gameCommissionRoute: Routes = [ + { + path: '', + component: GameCommissionComponent, + data: { + authorities: [Authority.USER], + pageTitle: 'GameCommissions' + }, + canActivate: [UserRouteAccessService] + }, + { + path: ':id/view', + component: GameCommissionDetailComponent, + resolve: { + gameCommission: GameCommissionResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'GameCommissions' + }, + canActivate: [UserRouteAccessService] + }, + { + path: 'new', + component: GameCommissionUpdateComponent, + resolve: { + gameCommission: GameCommissionResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'GameCommissions' + }, + canActivate: [UserRouteAccessService] + }, + { + path: ':id/edit', + component: GameCommissionUpdateComponent, + resolve: { + gameCommission: GameCommissionResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'GameCommissions' + }, + canActivate: [UserRouteAccessService] + } +]; diff --git a/src/main/webapp/app/entities/game-commission/game-commission.service.ts b/src/main/webapp/app/entities/game-commission/game-commission.service.ts new file mode 100644 index 0000000..5d13ab7 --- /dev/null +++ b/src/main/webapp/app/entities/game-commission/game-commission.service.ts @@ -0,0 +1,38 @@ +import { Injectable } from '@angular/core'; +import { HttpClient, HttpResponse } from '@angular/common/http'; +import { Observable } from 'rxjs'; + +import { SERVER_API_URL } from 'app/app.constants'; +import { createRequestOption } from 'app/shared/util/request-util'; +import { IGameCommission } from 'app/shared/model/game-commission.model'; + +type EntityResponseType = HttpResponse; +type EntityArrayResponseType = HttpResponse; + +@Injectable({ providedIn: 'root' }) +export class GameCommissionService { + public resourceUrl = SERVER_API_URL + 'api/game-commissions'; + + constructor(protected http: HttpClient) {} + + create(gameCommission: IGameCommission): Observable { + return this.http.post(this.resourceUrl, gameCommission, { observe: 'response' }); + } + + update(gameCommission: IGameCommission): Observable { + return this.http.put(this.resourceUrl, gameCommission, { observe: 'response' }); + } + + find(id: number): Observable { + return this.http.get(`${this.resourceUrl}/${id}`, { observe: 'response' }); + } + + query(req?: any): Observable { + const options = createRequestOption(req); + return this.http.get(this.resourceUrl, { params: options, observe: 'response' }); + } + + delete(id: number): Observable> { + return this.http.delete(`${this.resourceUrl}/${id}`, { observe: 'response' }); + } +} diff --git a/src/main/webapp/app/entities/game-user/game-user-delete-dialog.component.html b/src/main/webapp/app/entities/game-user/game-user-delete-dialog.component.html new file mode 100644 index 0000000..7ccb2b3 --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user-delete-dialog.component.html @@ -0,0 +1,24 @@ +
+ + + + + +
diff --git a/src/main/webapp/app/entities/game-user/game-user-delete-dialog.component.ts b/src/main/webapp/app/entities/game-user/game-user-delete-dialog.component.ts new file mode 100644 index 0000000..4d768e0 --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user-delete-dialog.component.ts @@ -0,0 +1,26 @@ +import { Component } from '@angular/core'; +import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap'; +import { JhiEventManager } from 'ng-jhipster'; + +import { IGameUser } from 'app/shared/model/game-user.model'; +import { GameUserService } from './game-user.service'; + +@Component({ + templateUrl: './game-user-delete-dialog.component.html' +}) +export class GameUserDeleteDialogComponent { + gameUser?: IGameUser; + + constructor(protected gameUserService: GameUserService, public activeModal: NgbActiveModal, protected eventManager: JhiEventManager) {} + + cancel(): void { + this.activeModal.dismiss(); + } + + confirmDelete(id: number): void { + this.gameUserService.delete(id).subscribe(() => { + this.eventManager.broadcast('gameUserListModification'); + this.activeModal.close(); + }); + } +} diff --git a/src/main/webapp/app/entities/game-user/game-user-detail.component.html b/src/main/webapp/app/entities/game-user/game-user-detail.component.html new file mode 100644 index 0000000..14f418b --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user-detail.component.html @@ -0,0 +1,34 @@ +
+
+
+

Game User {{ gameUser.id }}

+ +
+ + + +
+
Username
+
+ {{ gameUser.username }} +
+
Password
+
+ {{ gameUser.password }} +
+
+ + + + +
+
+
diff --git a/src/main/webapp/app/entities/game-user/game-user-detail.component.ts b/src/main/webapp/app/entities/game-user/game-user-detail.component.ts new file mode 100644 index 0000000..3f68a7b --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user-detail.component.ts @@ -0,0 +1,22 @@ +import { Component, OnInit } from '@angular/core'; +import { ActivatedRoute } from '@angular/router'; + +import { IGameUser } from 'app/shared/model/game-user.model'; + +@Component({ + selector: 'jhi-game-user-detail', + templateUrl: './game-user-detail.component.html' +}) +export class GameUserDetailComponent implements OnInit { + gameUser: IGameUser | null = null; + + constructor(protected activatedRoute: ActivatedRoute) {} + + ngOnInit(): void { + this.activatedRoute.data.subscribe(({ gameUser }) => (this.gameUser = gameUser)); + } + + previousState(): void { + window.history.back(); + } +} diff --git a/src/main/webapp/app/entities/game-user/game-user-update.component.html b/src/main/webapp/app/entities/game-user/game-user-update.component.html new file mode 100644 index 0000000..82469b4 --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user-update.component.html @@ -0,0 +1,38 @@ +
+
+
+

Create or edit a Game User

+ +
+ + +
+ + +
+ +
+ + +
+ +
+ + +
+
+ +
+ + + +
+
+
+
diff --git a/src/main/webapp/app/entities/game-user/game-user-update.component.ts b/src/main/webapp/app/entities/game-user/game-user-update.component.ts new file mode 100644 index 0000000..e22965f --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user-update.component.ts @@ -0,0 +1,78 @@ +import { Component, OnInit } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +// eslint-disable-next-line @typescript-eslint/no-unused-vars +import { FormBuilder, Validators } from '@angular/forms'; +import { ActivatedRoute } from '@angular/router'; +import { Observable } from 'rxjs'; + +import { IGameUser, GameUser } from 'app/shared/model/game-user.model'; +import { GameUserService } from './game-user.service'; + +@Component({ + selector: 'jhi-game-user-update', + templateUrl: './game-user-update.component.html' +}) +export class GameUserUpdateComponent implements OnInit { + isSaving = false; + + editForm = this.fb.group({ + id: [], + username: [], + password: [] + }); + + constructor(protected gameUserService: GameUserService, protected activatedRoute: ActivatedRoute, private fb: FormBuilder) {} + + ngOnInit(): void { + this.activatedRoute.data.subscribe(({ gameUser }) => { + this.updateForm(gameUser); + }); + } + + updateForm(gameUser: IGameUser): void { + this.editForm.patchValue({ + id: gameUser.id, + username: gameUser.username, + password: gameUser.password + }); + } + + previousState(): void { + window.history.back(); + } + + save(): void { + this.isSaving = true; + const gameUser = this.createFromForm(); + if (gameUser.id !== undefined) { + this.subscribeToSaveResponse(this.gameUserService.update(gameUser)); + } else { + this.subscribeToSaveResponse(this.gameUserService.create(gameUser)); + } + } + + private createFromForm(): IGameUser { + return { + ...new GameUser(), + id: this.editForm.get(['id'])!.value, + username: this.editForm.get(['username'])!.value, + password: this.editForm.get(['password'])!.value + }; + } + + protected subscribeToSaveResponse(result: Observable>): void { + result.subscribe( + () => this.onSaveSuccess(), + () => this.onSaveError() + ); + } + + protected onSaveSuccess(): void { + this.isSaving = false; + this.previousState(); + } + + protected onSaveError(): void { + this.isSaving = false; + } +} diff --git a/src/main/webapp/app/entities/game-user/game-user.component.html b/src/main/webapp/app/entities/game-user/game-user.component.html new file mode 100644 index 0000000..500121b --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user.component.html @@ -0,0 +1,63 @@ +
+

+ Game Users + + +

+ + + + + +
+ No gameUsers found +
+ +
+ + + + + + + + + + + + + + + + + +
IDUsernamePassword
{{ gameUser.id }}{{ gameUser.username }}{{ gameUser.password }} +
+ + + + + +
+
+
+
diff --git a/src/main/webapp/app/entities/game-user/game-user.component.ts b/src/main/webapp/app/entities/game-user/game-user.component.ts new file mode 100644 index 0000000..872b63e --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user.component.ts @@ -0,0 +1,49 @@ +import { Component, OnInit, OnDestroy } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +import { Subscription } from 'rxjs'; +import { JhiEventManager } from 'ng-jhipster'; +import { NgbModal } from '@ng-bootstrap/ng-bootstrap'; + +import { IGameUser } from 'app/shared/model/game-user.model'; +import { GameUserService } from './game-user.service'; +import { GameUserDeleteDialogComponent } from './game-user-delete-dialog.component'; + +@Component({ + selector: 'jhi-game-user', + templateUrl: './game-user.component.html' +}) +export class GameUserComponent implements OnInit, OnDestroy { + gameUsers?: IGameUser[]; + eventSubscriber?: Subscription; + + constructor(protected gameUserService: GameUserService, protected eventManager: JhiEventManager, protected modalService: NgbModal) {} + + loadAll(): void { + this.gameUserService.query().subscribe((res: HttpResponse) => (this.gameUsers = res.body || [])); + } + + ngOnInit(): void { + this.loadAll(); + this.registerChangeInGameUsers(); + } + + ngOnDestroy(): void { + if (this.eventSubscriber) { + this.eventManager.destroy(this.eventSubscriber); + } + } + + trackId(index: number, item: IGameUser): number { + // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion + return item.id!; + } + + registerChangeInGameUsers(): void { + this.eventSubscriber = this.eventManager.subscribe('gameUserListModification', () => this.loadAll()); + } + + delete(gameUser: IGameUser): void { + const modalRef = this.modalService.open(GameUserDeleteDialogComponent, { size: 'lg', backdrop: 'static' }); + modalRef.componentInstance.gameUser = gameUser; + } +} diff --git a/src/main/webapp/app/entities/game-user/game-user.module.ts b/src/main/webapp/app/entities/game-user/game-user.module.ts new file mode 100644 index 0000000..e5c1902 --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user.module.ts @@ -0,0 +1,16 @@ +import { NgModule } from '@angular/core'; +import { RouterModule } from '@angular/router'; + +import { AdminSharedModule } from 'app/shared/shared.module'; +import { GameUserComponent } from './game-user.component'; +import { GameUserDetailComponent } from './game-user-detail.component'; +import { GameUserUpdateComponent } from './game-user-update.component'; +import { GameUserDeleteDialogComponent } from './game-user-delete-dialog.component'; +import { gameUserRoute } from './game-user.route'; + +@NgModule({ + imports: [AdminSharedModule, RouterModule.forChild(gameUserRoute)], + declarations: [GameUserComponent, GameUserDetailComponent, GameUserUpdateComponent, GameUserDeleteDialogComponent], + entryComponents: [GameUserDeleteDialogComponent] +}) +export class AdminGameUserModule {} diff --git a/src/main/webapp/app/entities/game-user/game-user.route.ts b/src/main/webapp/app/entities/game-user/game-user.route.ts new file mode 100644 index 0000000..4b70389 --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user.route.ts @@ -0,0 +1,83 @@ +import { Injectable } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +import { Resolve, ActivatedRouteSnapshot, Routes, Router } from '@angular/router'; +import { Observable, of, EMPTY } from 'rxjs'; +import { flatMap } from 'rxjs/operators'; + +import { Authority } from 'app/shared/constants/authority.constants'; +import { UserRouteAccessService } from 'app/core/auth/user-route-access-service'; +import { IGameUser, GameUser } from 'app/shared/model/game-user.model'; +import { GameUserService } from './game-user.service'; +import { GameUserComponent } from './game-user.component'; +import { GameUserDetailComponent } from './game-user-detail.component'; +import { GameUserUpdateComponent } from './game-user-update.component'; + +@Injectable({ providedIn: 'root' }) +export class GameUserResolve implements Resolve { + constructor(private service: GameUserService, private router: Router) {} + + resolve(route: ActivatedRouteSnapshot): Observable | Observable { + const id = route.params['id']; + if (id) { + return this.service.find(id).pipe( + flatMap((gameUser: HttpResponse) => { + if (gameUser.body) { + return of(gameUser.body); + } else { + this.router.navigate(['404']); + return EMPTY; + } + }) + ); + } + return of(new GameUser()); + } +} + +export const gameUserRoute: Routes = [ + { + path: '', + component: GameUserComponent, + data: { + authorities: [Authority.USER], + pageTitle: 'GameUsers' + }, + canActivate: [UserRouteAccessService] + }, + { + path: ':id/view', + component: GameUserDetailComponent, + resolve: { + gameUser: GameUserResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'GameUsers' + }, + canActivate: [UserRouteAccessService] + }, + { + path: 'new', + component: GameUserUpdateComponent, + resolve: { + gameUser: GameUserResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'GameUsers' + }, + canActivate: [UserRouteAccessService] + }, + { + path: ':id/edit', + component: GameUserUpdateComponent, + resolve: { + gameUser: GameUserResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'GameUsers' + }, + canActivate: [UserRouteAccessService] + } +]; diff --git a/src/main/webapp/app/entities/game-user/game-user.service.ts b/src/main/webapp/app/entities/game-user/game-user.service.ts new file mode 100644 index 0000000..a4089e1 --- /dev/null +++ b/src/main/webapp/app/entities/game-user/game-user.service.ts @@ -0,0 +1,38 @@ +import { Injectable } from '@angular/core'; +import { HttpClient, HttpResponse } from '@angular/common/http'; +import { Observable } from 'rxjs'; + +import { SERVER_API_URL } from 'app/app.constants'; +import { createRequestOption } from 'app/shared/util/request-util'; +import { IGameUser } from 'app/shared/model/game-user.model'; + +type EntityResponseType = HttpResponse; +type EntityArrayResponseType = HttpResponse; + +@Injectable({ providedIn: 'root' }) +export class GameUserService { + public resourceUrl = SERVER_API_URL + 'api/game-users'; + + constructor(protected http: HttpClient) {} + + create(gameUser: IGameUser): Observable { + return this.http.post(this.resourceUrl, gameUser, { observe: 'response' }); + } + + update(gameUser: IGameUser): Observable { + return this.http.put(this.resourceUrl, gameUser, { observe: 'response' }); + } + + find(id: number): Observable { + return this.http.get(`${this.resourceUrl}/${id}`, { observe: 'response' }); + } + + query(req?: any): Observable { + const options = createRequestOption(req); + return this.http.get(this.resourceUrl, { params: options, observe: 'response' }); + } + + delete(id: number): Observable> { + return this.http.delete(`${this.resourceUrl}/${id}`, { observe: 'response' }); + } +} diff --git a/src/main/webapp/app/entities/game/game-delete-dialog.component.html b/src/main/webapp/app/entities/game/game-delete-dialog.component.html new file mode 100644 index 0000000..59e1b8a --- /dev/null +++ b/src/main/webapp/app/entities/game/game-delete-dialog.component.html @@ -0,0 +1,24 @@ +
+ + + + + +
diff --git a/src/main/webapp/app/entities/game/game-delete-dialog.component.ts b/src/main/webapp/app/entities/game/game-delete-dialog.component.ts new file mode 100644 index 0000000..0bccb2e --- /dev/null +++ b/src/main/webapp/app/entities/game/game-delete-dialog.component.ts @@ -0,0 +1,26 @@ +import { Component } from '@angular/core'; +import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap'; +import { JhiEventManager } from 'ng-jhipster'; + +import { IGame } from 'app/shared/model/game.model'; +import { GameService } from './game.service'; + +@Component({ + templateUrl: './game-delete-dialog.component.html' +}) +export class GameDeleteDialogComponent { + game?: IGame; + + constructor(protected gameService: GameService, public activeModal: NgbActiveModal, protected eventManager: JhiEventManager) {} + + cancel(): void { + this.activeModal.dismiss(); + } + + confirmDelete(id: number): void { + this.gameService.delete(id).subscribe(() => { + this.eventManager.broadcast('gameListModification'); + this.activeModal.close(); + }); + } +} diff --git a/src/main/webapp/app/entities/game/game-detail.component.html b/src/main/webapp/app/entities/game/game-detail.component.html new file mode 100644 index 0000000..78359b0 --- /dev/null +++ b/src/main/webapp/app/entities/game/game-detail.component.html @@ -0,0 +1,30 @@ +
+
+
+

Game {{ game.id }}

+ +
+ + + +
+
Name
+
+ {{ game.name }} +
+
+ + + + +
+
+
diff --git a/src/main/webapp/app/entities/game/game-detail.component.ts b/src/main/webapp/app/entities/game/game-detail.component.ts new file mode 100644 index 0000000..1ee14ee --- /dev/null +++ b/src/main/webapp/app/entities/game/game-detail.component.ts @@ -0,0 +1,22 @@ +import { Component, OnInit } from '@angular/core'; +import { ActivatedRoute } from '@angular/router'; + +import { IGame } from 'app/shared/model/game.model'; + +@Component({ + selector: 'jhi-game-detail', + templateUrl: './game-detail.component.html' +}) +export class GameDetailComponent implements OnInit { + game: IGame | null = null; + + constructor(protected activatedRoute: ActivatedRoute) {} + + ngOnInit(): void { + this.activatedRoute.data.subscribe(({ game }) => (this.game = game)); + } + + previousState(): void { + window.history.back(); + } +} diff --git a/src/main/webapp/app/entities/game/game-update.component.html b/src/main/webapp/app/entities/game/game-update.component.html new file mode 100644 index 0000000..6361c0e --- /dev/null +++ b/src/main/webapp/app/entities/game/game-update.component.html @@ -0,0 +1,32 @@ +
+
+
+

Create or edit a Game

+ +
+ + +
+ + +
+ +
+ + +
+
+ +
+ + + +
+
+
+
diff --git a/src/main/webapp/app/entities/game/game-update.component.ts b/src/main/webapp/app/entities/game/game-update.component.ts new file mode 100644 index 0000000..d97a1fa --- /dev/null +++ b/src/main/webapp/app/entities/game/game-update.component.ts @@ -0,0 +1,75 @@ +import { Component, OnInit } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +// eslint-disable-next-line @typescript-eslint/no-unused-vars +import { FormBuilder, Validators } from '@angular/forms'; +import { ActivatedRoute } from '@angular/router'; +import { Observable } from 'rxjs'; + +import { IGame, Game } from 'app/shared/model/game.model'; +import { GameService } from './game.service'; + +@Component({ + selector: 'jhi-game-update', + templateUrl: './game-update.component.html' +}) +export class GameUpdateComponent implements OnInit { + isSaving = false; + + editForm = this.fb.group({ + id: [], + name: [] + }); + + constructor(protected gameService: GameService, protected activatedRoute: ActivatedRoute, private fb: FormBuilder) {} + + ngOnInit(): void { + this.activatedRoute.data.subscribe(({ game }) => { + this.updateForm(game); + }); + } + + updateForm(game: IGame): void { + this.editForm.patchValue({ + id: game.id, + name: game.name + }); + } + + previousState(): void { + window.history.back(); + } + + save(): void { + this.isSaving = true; + const game = this.createFromForm(); + if (game.id !== undefined) { + this.subscribeToSaveResponse(this.gameService.update(game)); + } else { + this.subscribeToSaveResponse(this.gameService.create(game)); + } + } + + private createFromForm(): IGame { + return { + ...new Game(), + id: this.editForm.get(['id'])!.value, + name: this.editForm.get(['name'])!.value + }; + } + + protected subscribeToSaveResponse(result: Observable>): void { + result.subscribe( + () => this.onSaveSuccess(), + () => this.onSaveError() + ); + } + + protected onSaveSuccess(): void { + this.isSaving = false; + this.previousState(); + } + + protected onSaveError(): void { + this.isSaving = false; + } +} diff --git a/src/main/webapp/app/entities/game/game.component.html b/src/main/webapp/app/entities/game/game.component.html new file mode 100644 index 0000000..d309c29 --- /dev/null +++ b/src/main/webapp/app/entities/game/game.component.html @@ -0,0 +1,61 @@ +
+

+ Games + + +

+ + + + + +
+ No games found +
+ +
+ + + + + + + + + + + + + + + +
IDName
{{ game.id }}{{ game.name }} +
+ + + + + +
+
+
+
diff --git a/src/main/webapp/app/entities/game/game.component.ts b/src/main/webapp/app/entities/game/game.component.ts new file mode 100644 index 0000000..33370fb --- /dev/null +++ b/src/main/webapp/app/entities/game/game.component.ts @@ -0,0 +1,49 @@ +import { Component, OnInit, OnDestroy } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +import { Subscription } from 'rxjs'; +import { JhiEventManager } from 'ng-jhipster'; +import { NgbModal } from '@ng-bootstrap/ng-bootstrap'; + +import { IGame } from 'app/shared/model/game.model'; +import { GameService } from './game.service'; +import { GameDeleteDialogComponent } from './game-delete-dialog.component'; + +@Component({ + selector: 'jhi-game', + templateUrl: './game.component.html' +}) +export class GameComponent implements OnInit, OnDestroy { + games?: IGame[]; + eventSubscriber?: Subscription; + + constructor(protected gameService: GameService, protected eventManager: JhiEventManager, protected modalService: NgbModal) {} + + loadAll(): void { + this.gameService.query().subscribe((res: HttpResponse) => (this.games = res.body || [])); + } + + ngOnInit(): void { + this.loadAll(); + this.registerChangeInGames(); + } + + ngOnDestroy(): void { + if (this.eventSubscriber) { + this.eventManager.destroy(this.eventSubscriber); + } + } + + trackId(index: number, item: IGame): number { + // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion + return item.id!; + } + + registerChangeInGames(): void { + this.eventSubscriber = this.eventManager.subscribe('gameListModification', () => this.loadAll()); + } + + delete(game: IGame): void { + const modalRef = this.modalService.open(GameDeleteDialogComponent, { size: 'lg', backdrop: 'static' }); + modalRef.componentInstance.game = game; + } +} diff --git a/src/main/webapp/app/entities/game/game.module.ts b/src/main/webapp/app/entities/game/game.module.ts new file mode 100644 index 0000000..756441f --- /dev/null +++ b/src/main/webapp/app/entities/game/game.module.ts @@ -0,0 +1,16 @@ +import { NgModule } from '@angular/core'; +import { RouterModule } from '@angular/router'; + +import { AdminSharedModule } from 'app/shared/shared.module'; +import { GameComponent } from './game.component'; +import { GameDetailComponent } from './game-detail.component'; +import { GameUpdateComponent } from './game-update.component'; +import { GameDeleteDialogComponent } from './game-delete-dialog.component'; +import { gameRoute } from './game.route'; + +@NgModule({ + imports: [AdminSharedModule, RouterModule.forChild(gameRoute)], + declarations: [GameComponent, GameDetailComponent, GameUpdateComponent, GameDeleteDialogComponent], + entryComponents: [GameDeleteDialogComponent] +}) +export class AdminGameModule {} diff --git a/src/main/webapp/app/entities/game/game.route.ts b/src/main/webapp/app/entities/game/game.route.ts new file mode 100644 index 0000000..61d2560 --- /dev/null +++ b/src/main/webapp/app/entities/game/game.route.ts @@ -0,0 +1,83 @@ +import { Injectable } from '@angular/core'; +import { HttpResponse } from '@angular/common/http'; +import { Resolve, ActivatedRouteSnapshot, Routes, Router } from '@angular/router'; +import { Observable, of, EMPTY } from 'rxjs'; +import { flatMap } from 'rxjs/operators'; + +import { Authority } from 'app/shared/constants/authority.constants'; +import { UserRouteAccessService } from 'app/core/auth/user-route-access-service'; +import { IGame, Game } from 'app/shared/model/game.model'; +import { GameService } from './game.service'; +import { GameComponent } from './game.component'; +import { GameDetailComponent } from './game-detail.component'; +import { GameUpdateComponent } from './game-update.component'; + +@Injectable({ providedIn: 'root' }) +export class GameResolve implements Resolve { + constructor(private service: GameService, private router: Router) {} + + resolve(route: ActivatedRouteSnapshot): Observable | Observable { + const id = route.params['id']; + if (id) { + return this.service.find(id).pipe( + flatMap((game: HttpResponse) => { + if (game.body) { + return of(game.body); + } else { + this.router.navigate(['404']); + return EMPTY; + } + }) + ); + } + return of(new Game()); + } +} + +export const gameRoute: Routes = [ + { + path: '', + component: GameComponent, + data: { + authorities: [Authority.USER], + pageTitle: 'Games' + }, + canActivate: [UserRouteAccessService] + }, + { + path: ':id/view', + component: GameDetailComponent, + resolve: { + game: GameResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'Games' + }, + canActivate: [UserRouteAccessService] + }, + { + path: 'new', + component: GameUpdateComponent, + resolve: { + game: GameResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'Games' + }, + canActivate: [UserRouteAccessService] + }, + { + path: ':id/edit', + component: GameUpdateComponent, + resolve: { + game: GameResolve + }, + data: { + authorities: [Authority.USER], + pageTitle: 'Games' + }, + canActivate: [UserRouteAccessService] + } +]; diff --git a/src/main/webapp/app/entities/game/game.service.ts b/src/main/webapp/app/entities/game/game.service.ts new file mode 100644 index 0000000..191c9f3 --- /dev/null +++ b/src/main/webapp/app/entities/game/game.service.ts @@ -0,0 +1,38 @@ +import { Injectable } from '@angular/core'; +import { HttpClient, HttpResponse } from '@angular/common/http'; +import { Observable } from 'rxjs'; + +import { SERVER_API_URL } from 'app/app.constants'; +import { createRequestOption } from 'app/shared/util/request-util'; +import { IGame } from 'app/shared/model/game.model'; + +type EntityResponseType = HttpResponse; +type EntityArrayResponseType = HttpResponse; + +@Injectable({ providedIn: 'root' }) +export class GameService { + public resourceUrl = SERVER_API_URL + 'api/games'; + + constructor(protected http: HttpClient) {} + + create(game: IGame): Observable { + return this.http.post(this.resourceUrl, game, { observe: 'response' }); + } + + update(game: IGame): Observable { + return this.http.put(this.resourceUrl, game, { observe: 'response' }); + } + + find(id: number): Observable { + return this.http.get(`${this.resourceUrl}/${id}`, { observe: 'response' }); + } + + query(req?: any): Observable { + const options = createRequestOption(req); + return this.http.get(this.resourceUrl, { params: options, observe: 'response' }); + } + + delete(id: number): Observable> { + return this.http.delete(`${this.resourceUrl}/${id}`, { observe: 'response' }); + } +} diff --git a/src/main/webapp/app/layouts/navbar/navbar.component.html b/src/main/webapp/app/layouts/navbar/navbar.component.html index ade57c8..aa8a785 100644 --- a/src/main/webapp/app/layouts/navbar/navbar.component.html +++ b/src/main/webapp/app/layouts/navbar/navbar.component.html @@ -27,6 +27,24 @@ diff --git a/src/main/webapp/app/shared/model/game-commission.model.ts b/src/main/webapp/app/shared/model/game-commission.model.ts new file mode 100644 index 0000000..1cfa73e --- /dev/null +++ b/src/main/webapp/app/shared/model/game-commission.model.ts @@ -0,0 +1,13 @@ +import { IGameUser } from 'app/shared/model/game-user.model'; +import { IGame } from 'app/shared/model/game.model'; + +export interface IGameCommission { + id?: number; + commission?: number; + gameUser?: IGameUser; + game?: IGame; +} + +export class GameCommission implements IGameCommission { + constructor(public id?: number, public commission?: number, public gameUser?: IGameUser, public game?: IGame) {} +} diff --git a/src/main/webapp/app/shared/model/game-user.model.ts b/src/main/webapp/app/shared/model/game-user.model.ts new file mode 100644 index 0000000..1327a19 --- /dev/null +++ b/src/main/webapp/app/shared/model/game-user.model.ts @@ -0,0 +1,12 @@ +import { IGameCommission } from 'app/shared/model/game-commission.model'; + +export interface IGameUser { + id?: number; + username?: string; + password?: string; + commissions?: IGameCommission[]; +} + +export class GameUser implements IGameUser { + constructor(public id?: number, public username?: string, public password?: string, public commissions?: IGameCommission[]) {} +} diff --git a/src/main/webapp/app/shared/model/game.model.ts b/src/main/webapp/app/shared/model/game.model.ts new file mode 100644 index 0000000..84137ee --- /dev/null +++ b/src/main/webapp/app/shared/model/game.model.ts @@ -0,0 +1,11 @@ +import { IGameCommission } from 'app/shared/model/game-commission.model'; + +export interface IGame { + id?: number; + name?: string; + gameCommissions?: IGameCommission[]; +} + +export class Game implements IGame { + constructor(public id?: number, public name?: string, public gameCommissions?: IGameCommission[]) {} +} diff --git a/src/test/java/com/mycompany/myapp/domain/GameCommissionTest.java b/src/test/java/com/mycompany/myapp/domain/GameCommissionTest.java new file mode 100644 index 0000000..74fdd2d --- /dev/null +++ b/src/test/java/com/mycompany/myapp/domain/GameCommissionTest.java @@ -0,0 +1,22 @@ +package com.mycompany.myapp.domain; + +import org.junit.jupiter.api.Test; +import static org.assertj.core.api.Assertions.assertThat; +import com.mycompany.myapp.web.rest.TestUtil; + +public class GameCommissionTest { + + @Test + public void equalsVerifier() throws Exception { + TestUtil.equalsVerifier(GameCommission.class); + GameCommission gameCommission1 = new GameCommission(); + gameCommission1.setId(1L); + GameCommission gameCommission2 = new GameCommission(); + gameCommission2.setId(gameCommission1.getId()); + assertThat(gameCommission1).isEqualTo(gameCommission2); + gameCommission2.setId(2L); + assertThat(gameCommission1).isNotEqualTo(gameCommission2); + gameCommission1.setId(null); + assertThat(gameCommission1).isNotEqualTo(gameCommission2); + } +} diff --git a/src/test/java/com/mycompany/myapp/domain/GameTest.java b/src/test/java/com/mycompany/myapp/domain/GameTest.java new file mode 100644 index 0000000..8bb39b6 --- /dev/null +++ b/src/test/java/com/mycompany/myapp/domain/GameTest.java @@ -0,0 +1,22 @@ +package com.mycompany.myapp.domain; + +import org.junit.jupiter.api.Test; +import static org.assertj.core.api.Assertions.assertThat; +import com.mycompany.myapp.web.rest.TestUtil; + +public class GameTest { + + @Test + public void equalsVerifier() throws Exception { + TestUtil.equalsVerifier(Game.class); + Game game1 = new Game(); + game1.setId(1L); + Game game2 = new Game(); + game2.setId(game1.getId()); + assertThat(game1).isEqualTo(game2); + game2.setId(2L); + assertThat(game1).isNotEqualTo(game2); + game1.setId(null); + assertThat(game1).isNotEqualTo(game2); + } +} diff --git a/src/test/java/com/mycompany/myapp/domain/GameUserTest.java b/src/test/java/com/mycompany/myapp/domain/GameUserTest.java new file mode 100644 index 0000000..93c0408 --- /dev/null +++ b/src/test/java/com/mycompany/myapp/domain/GameUserTest.java @@ -0,0 +1,22 @@ +package com.mycompany.myapp.domain; + +import org.junit.jupiter.api.Test; +import static org.assertj.core.api.Assertions.assertThat; +import com.mycompany.myapp.web.rest.TestUtil; + +public class GameUserTest { + + @Test + public void equalsVerifier() throws Exception { + TestUtil.equalsVerifier(GameUser.class); + GameUser gameUser1 = new GameUser(); + gameUser1.setId(1L); + GameUser gameUser2 = new GameUser(); + gameUser2.setId(gameUser1.getId()); + assertThat(gameUser1).isEqualTo(gameUser2); + gameUser2.setId(2L); + assertThat(gameUser1).isNotEqualTo(gameUser2); + gameUser1.setId(null); + assertThat(gameUser1).isNotEqualTo(gameUser2); + } +} diff --git a/src/test/java/com/mycompany/myapp/web/rest/GameCommissionResourceIT.java b/src/test/java/com/mycompany/myapp/web/rest/GameCommissionResourceIT.java new file mode 100644 index 0000000..1ac6fea --- /dev/null +++ b/src/test/java/com/mycompany/myapp/web/rest/GameCommissionResourceIT.java @@ -0,0 +1,211 @@ +package com.mycompany.myapp.web.rest; + +import com.mycompany.myapp.AdminApp; +import com.mycompany.myapp.domain.GameCommission; +import com.mycompany.myapp.repository.GameCommissionRepository; + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.http.MediaType; +import org.springframework.security.test.context.support.WithMockUser; +import org.springframework.test.web.servlet.MockMvc; +import org.springframework.transaction.annotation.Transactional; +import javax.persistence.EntityManager; +import java.util.List; + +import static org.assertj.core.api.Assertions.assertThat; +import static org.hamcrest.Matchers.hasItem; +import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.*; + +/** + * Integration tests for the {@link GameCommissionResource} REST controller. + */ +@SpringBootTest(classes = AdminApp.class) + +@AutoConfigureMockMvc +@WithMockUser +public class GameCommissionResourceIT { + + private static final Integer DEFAULT_COMMISSION = 1; + private static final Integer UPDATED_COMMISSION = 2; + + @Autowired + private GameCommissionRepository gameCommissionRepository; + + @Autowired + private EntityManager em; + + @Autowired + private MockMvc restGameCommissionMockMvc; + + private GameCommission gameCommission; + + /** + * Create an entity for this test. + * + * This is a static method, as tests for other entities might also need it, + * if they test an entity which requires the current entity. + */ + public static GameCommission createEntity(EntityManager em) { + GameCommission gameCommission = new GameCommission() + .commission(DEFAULT_COMMISSION); + return gameCommission; + } + /** + * Create an updated entity for this test. + * + * This is a static method, as tests for other entities might also need it, + * if they test an entity which requires the current entity. + */ + public static GameCommission createUpdatedEntity(EntityManager em) { + GameCommission gameCommission = new GameCommission() + .commission(UPDATED_COMMISSION); + return gameCommission; + } + + @BeforeEach + public void initTest() { + gameCommission = createEntity(em); + } + + @Test + @Transactional + public void createGameCommission() throws Exception { + int databaseSizeBeforeCreate = gameCommissionRepository.findAll().size(); + + // Create the GameCommission + restGameCommissionMockMvc.perform(post("/api/game-commissions") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(gameCommission))) + .andExpect(status().isCreated()); + + // Validate the GameCommission in the database + List gameCommissionList = gameCommissionRepository.findAll(); + assertThat(gameCommissionList).hasSize(databaseSizeBeforeCreate + 1); + GameCommission testGameCommission = gameCommissionList.get(gameCommissionList.size() - 1); + assertThat(testGameCommission.getCommission()).isEqualTo(DEFAULT_COMMISSION); + } + + @Test + @Transactional + public void createGameCommissionWithExistingId() throws Exception { + int databaseSizeBeforeCreate = gameCommissionRepository.findAll().size(); + + // Create the GameCommission with an existing ID + gameCommission.setId(1L); + + // An entity with an existing ID cannot be created, so this API call must fail + restGameCommissionMockMvc.perform(post("/api/game-commissions") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(gameCommission))) + .andExpect(status().isBadRequest()); + + // Validate the GameCommission in the database + List gameCommissionList = gameCommissionRepository.findAll(); + assertThat(gameCommissionList).hasSize(databaseSizeBeforeCreate); + } + + + @Test + @Transactional + public void getAllGameCommissions() throws Exception { + // Initialize the database + gameCommissionRepository.saveAndFlush(gameCommission); + + // Get all the gameCommissionList + restGameCommissionMockMvc.perform(get("/api/game-commissions?sort=id,desc")) + .andExpect(status().isOk()) + .andExpect(content().contentType(MediaType.APPLICATION_JSON_VALUE)) + .andExpect(jsonPath("$.[*].id").value(hasItem(gameCommission.getId().intValue()))) + .andExpect(jsonPath("$.[*].commission").value(hasItem(DEFAULT_COMMISSION))); + } + + @Test + @Transactional + public void getGameCommission() throws Exception { + // Initialize the database + gameCommissionRepository.saveAndFlush(gameCommission); + + // Get the gameCommission + restGameCommissionMockMvc.perform(get("/api/game-commissions/{id}", gameCommission.getId())) + .andExpect(status().isOk()) + .andExpect(content().contentType(MediaType.APPLICATION_JSON_VALUE)) + .andExpect(jsonPath("$.id").value(gameCommission.getId().intValue())) + .andExpect(jsonPath("$.commission").value(DEFAULT_COMMISSION)); + } + + @Test + @Transactional + public void getNonExistingGameCommission() throws Exception { + // Get the gameCommission + restGameCommissionMockMvc.perform(get("/api/game-commissions/{id}", Long.MAX_VALUE)) + .andExpect(status().isNotFound()); + } + + @Test + @Transactional + public void updateGameCommission() throws Exception { + // Initialize the database + gameCommissionRepository.saveAndFlush(gameCommission); + + int databaseSizeBeforeUpdate = gameCommissionRepository.findAll().size(); + + // Update the gameCommission + GameCommission updatedGameCommission = gameCommissionRepository.findById(gameCommission.getId()).get(); + // Disconnect from session so that the updates on updatedGameCommission are not directly saved in db + em.detach(updatedGameCommission); + updatedGameCommission + .commission(UPDATED_COMMISSION); + + restGameCommissionMockMvc.perform(put("/api/game-commissions") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(updatedGameCommission))) + .andExpect(status().isOk()); + + // Validate the GameCommission in the database + List gameCommissionList = gameCommissionRepository.findAll(); + assertThat(gameCommissionList).hasSize(databaseSizeBeforeUpdate); + GameCommission testGameCommission = gameCommissionList.get(gameCommissionList.size() - 1); + assertThat(testGameCommission.getCommission()).isEqualTo(UPDATED_COMMISSION); + } + + @Test + @Transactional + public void updateNonExistingGameCommission() throws Exception { + int databaseSizeBeforeUpdate = gameCommissionRepository.findAll().size(); + + // Create the GameCommission + + // If the entity doesn't have an ID, it will throw BadRequestAlertException + restGameCommissionMockMvc.perform(put("/api/game-commissions") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(gameCommission))) + .andExpect(status().isBadRequest()); + + // Validate the GameCommission in the database + List gameCommissionList = gameCommissionRepository.findAll(); + assertThat(gameCommissionList).hasSize(databaseSizeBeforeUpdate); + } + + @Test + @Transactional + public void deleteGameCommission() throws Exception { + // Initialize the database + gameCommissionRepository.saveAndFlush(gameCommission); + + int databaseSizeBeforeDelete = gameCommissionRepository.findAll().size(); + + // Delete the gameCommission + restGameCommissionMockMvc.perform(delete("/api/game-commissions/{id}", gameCommission.getId()) + .accept(MediaType.APPLICATION_JSON)) + .andExpect(status().isNoContent()); + + // Validate the database contains one less item + List gameCommissionList = gameCommissionRepository.findAll(); + assertThat(gameCommissionList).hasSize(databaseSizeBeforeDelete - 1); + } +} diff --git a/src/test/java/com/mycompany/myapp/web/rest/GameResourceIT.java b/src/test/java/com/mycompany/myapp/web/rest/GameResourceIT.java new file mode 100644 index 0000000..dc02669 --- /dev/null +++ b/src/test/java/com/mycompany/myapp/web/rest/GameResourceIT.java @@ -0,0 +1,211 @@ +package com.mycompany.myapp.web.rest; + +import com.mycompany.myapp.AdminApp; +import com.mycompany.myapp.domain.Game; +import com.mycompany.myapp.repository.GameRepository; + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.http.MediaType; +import org.springframework.security.test.context.support.WithMockUser; +import org.springframework.test.web.servlet.MockMvc; +import org.springframework.transaction.annotation.Transactional; +import javax.persistence.EntityManager; +import java.util.List; + +import static org.assertj.core.api.Assertions.assertThat; +import static org.hamcrest.Matchers.hasItem; +import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.*; + +/** + * Integration tests for the {@link GameResource} REST controller. + */ +@SpringBootTest(classes = AdminApp.class) + +@AutoConfigureMockMvc +@WithMockUser +public class GameResourceIT { + + private static final String DEFAULT_NAME = "AAAAAAAAAA"; + private static final String UPDATED_NAME = "BBBBBBBBBB"; + + @Autowired + private GameRepository gameRepository; + + @Autowired + private EntityManager em; + + @Autowired + private MockMvc restGameMockMvc; + + private Game game; + + /** + * Create an entity for this test. + * + * This is a static method, as tests for other entities might also need it, + * if they test an entity which requires the current entity. + */ + public static Game createEntity(EntityManager em) { + Game game = new Game() + .name(DEFAULT_NAME); + return game; + } + /** + * Create an updated entity for this test. + * + * This is a static method, as tests for other entities might also need it, + * if they test an entity which requires the current entity. + */ + public static Game createUpdatedEntity(EntityManager em) { + Game game = new Game() + .name(UPDATED_NAME); + return game; + } + + @BeforeEach + public void initTest() { + game = createEntity(em); + } + + @Test + @Transactional + public void createGame() throws Exception { + int databaseSizeBeforeCreate = gameRepository.findAll().size(); + + // Create the Game + restGameMockMvc.perform(post("/api/games") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(game))) + .andExpect(status().isCreated()); + + // Validate the Game in the database + List gameList = gameRepository.findAll(); + assertThat(gameList).hasSize(databaseSizeBeforeCreate + 1); + Game testGame = gameList.get(gameList.size() - 1); + assertThat(testGame.getName()).isEqualTo(DEFAULT_NAME); + } + + @Test + @Transactional + public void createGameWithExistingId() throws Exception { + int databaseSizeBeforeCreate = gameRepository.findAll().size(); + + // Create the Game with an existing ID + game.setId(1L); + + // An entity with an existing ID cannot be created, so this API call must fail + restGameMockMvc.perform(post("/api/games") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(game))) + .andExpect(status().isBadRequest()); + + // Validate the Game in the database + List gameList = gameRepository.findAll(); + assertThat(gameList).hasSize(databaseSizeBeforeCreate); + } + + + @Test + @Transactional + public void getAllGames() throws Exception { + // Initialize the database + gameRepository.saveAndFlush(game); + + // Get all the gameList + restGameMockMvc.perform(get("/api/games?sort=id,desc")) + .andExpect(status().isOk()) + .andExpect(content().contentType(MediaType.APPLICATION_JSON_VALUE)) + .andExpect(jsonPath("$.[*].id").value(hasItem(game.getId().intValue()))) + .andExpect(jsonPath("$.[*].name").value(hasItem(DEFAULT_NAME))); + } + + @Test + @Transactional + public void getGame() throws Exception { + // Initialize the database + gameRepository.saveAndFlush(game); + + // Get the game + restGameMockMvc.perform(get("/api/games/{id}", game.getId())) + .andExpect(status().isOk()) + .andExpect(content().contentType(MediaType.APPLICATION_JSON_VALUE)) + .andExpect(jsonPath("$.id").value(game.getId().intValue())) + .andExpect(jsonPath("$.name").value(DEFAULT_NAME)); + } + + @Test + @Transactional + public void getNonExistingGame() throws Exception { + // Get the game + restGameMockMvc.perform(get("/api/games/{id}", Long.MAX_VALUE)) + .andExpect(status().isNotFound()); + } + + @Test + @Transactional + public void updateGame() throws Exception { + // Initialize the database + gameRepository.saveAndFlush(game); + + int databaseSizeBeforeUpdate = gameRepository.findAll().size(); + + // Update the game + Game updatedGame = gameRepository.findById(game.getId()).get(); + // Disconnect from session so that the updates on updatedGame are not directly saved in db + em.detach(updatedGame); + updatedGame + .name(UPDATED_NAME); + + restGameMockMvc.perform(put("/api/games") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(updatedGame))) + .andExpect(status().isOk()); + + // Validate the Game in the database + List gameList = gameRepository.findAll(); + assertThat(gameList).hasSize(databaseSizeBeforeUpdate); + Game testGame = gameList.get(gameList.size() - 1); + assertThat(testGame.getName()).isEqualTo(UPDATED_NAME); + } + + @Test + @Transactional + public void updateNonExistingGame() throws Exception { + int databaseSizeBeforeUpdate = gameRepository.findAll().size(); + + // Create the Game + + // If the entity doesn't have an ID, it will throw BadRequestAlertException + restGameMockMvc.perform(put("/api/games") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(game))) + .andExpect(status().isBadRequest()); + + // Validate the Game in the database + List gameList = gameRepository.findAll(); + assertThat(gameList).hasSize(databaseSizeBeforeUpdate); + } + + @Test + @Transactional + public void deleteGame() throws Exception { + // Initialize the database + gameRepository.saveAndFlush(game); + + int databaseSizeBeforeDelete = gameRepository.findAll().size(); + + // Delete the game + restGameMockMvc.perform(delete("/api/games/{id}", game.getId()) + .accept(MediaType.APPLICATION_JSON)) + .andExpect(status().isNoContent()); + + // Validate the database contains one less item + List gameList = gameRepository.findAll(); + assertThat(gameList).hasSize(databaseSizeBeforeDelete - 1); + } +} diff --git a/src/test/java/com/mycompany/myapp/web/rest/GameUserResourceIT.java b/src/test/java/com/mycompany/myapp/web/rest/GameUserResourceIT.java new file mode 100644 index 0000000..e49b2ee --- /dev/null +++ b/src/test/java/com/mycompany/myapp/web/rest/GameUserResourceIT.java @@ -0,0 +1,221 @@ +package com.mycompany.myapp.web.rest; + +import com.mycompany.myapp.AdminApp; +import com.mycompany.myapp.domain.GameUser; +import com.mycompany.myapp.repository.GameUserRepository; + +import org.junit.jupiter.api.BeforeEach; +import org.junit.jupiter.api.Test; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.boot.test.autoconfigure.web.servlet.AutoConfigureMockMvc; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.http.MediaType; +import org.springframework.security.test.context.support.WithMockUser; +import org.springframework.test.web.servlet.MockMvc; +import org.springframework.transaction.annotation.Transactional; +import javax.persistence.EntityManager; +import java.util.List; + +import static org.assertj.core.api.Assertions.assertThat; +import static org.hamcrest.Matchers.hasItem; +import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.*; +import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.*; + +/** + * Integration tests for the {@link GameUserResource} REST controller. + */ +@SpringBootTest(classes = AdminApp.class) + +@AutoConfigureMockMvc +@WithMockUser +public class GameUserResourceIT { + + private static final String DEFAULT_USERNAME = "AAAAAAAAAA"; + private static final String UPDATED_USERNAME = "BBBBBBBBBB"; + + private static final String DEFAULT_PASSWORD = "AAAAAAAAAA"; + private static final String UPDATED_PASSWORD = "BBBBBBBBBB"; + + @Autowired + private GameUserRepository gameUserRepository; + + @Autowired + private EntityManager em; + + @Autowired + private MockMvc restGameUserMockMvc; + + private GameUser gameUser; + + /** + * Create an entity for this test. + * + * This is a static method, as tests for other entities might also need it, + * if they test an entity which requires the current entity. + */ + public static GameUser createEntity(EntityManager em) { + GameUser gameUser = new GameUser() + .username(DEFAULT_USERNAME) + .password(DEFAULT_PASSWORD); + return gameUser; + } + /** + * Create an updated entity for this test. + * + * This is a static method, as tests for other entities might also need it, + * if they test an entity which requires the current entity. + */ + public static GameUser createUpdatedEntity(EntityManager em) { + GameUser gameUser = new GameUser() + .username(UPDATED_USERNAME) + .password(UPDATED_PASSWORD); + return gameUser; + } + + @BeforeEach + public void initTest() { + gameUser = createEntity(em); + } + + @Test + @Transactional + public void createGameUser() throws Exception { + int databaseSizeBeforeCreate = gameUserRepository.findAll().size(); + + // Create the GameUser + restGameUserMockMvc.perform(post("/api/game-users") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(gameUser))) + .andExpect(status().isCreated()); + + // Validate the GameUser in the database + List gameUserList = gameUserRepository.findAll(); + assertThat(gameUserList).hasSize(databaseSizeBeforeCreate + 1); + GameUser testGameUser = gameUserList.get(gameUserList.size() - 1); + assertThat(testGameUser.getUsername()).isEqualTo(DEFAULT_USERNAME); + assertThat(testGameUser.getPassword()).isEqualTo(DEFAULT_PASSWORD); + } + + @Test + @Transactional + public void createGameUserWithExistingId() throws Exception { + int databaseSizeBeforeCreate = gameUserRepository.findAll().size(); + + // Create the GameUser with an existing ID + gameUser.setId(1L); + + // An entity with an existing ID cannot be created, so this API call must fail + restGameUserMockMvc.perform(post("/api/game-users") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(gameUser))) + .andExpect(status().isBadRequest()); + + // Validate the GameUser in the database + List gameUserList = gameUserRepository.findAll(); + assertThat(gameUserList).hasSize(databaseSizeBeforeCreate); + } + + + @Test + @Transactional + public void getAllGameUsers() throws Exception { + // Initialize the database + gameUserRepository.saveAndFlush(gameUser); + + // Get all the gameUserList + restGameUserMockMvc.perform(get("/api/game-users?sort=id,desc")) + .andExpect(status().isOk()) + .andExpect(content().contentType(MediaType.APPLICATION_JSON_VALUE)) + .andExpect(jsonPath("$.[*].id").value(hasItem(gameUser.getId().intValue()))) + .andExpect(jsonPath("$.[*].username").value(hasItem(DEFAULT_USERNAME))) + .andExpect(jsonPath("$.[*].password").value(hasItem(DEFAULT_PASSWORD))); + } + + @Test + @Transactional + public void getGameUser() throws Exception { + // Initialize the database + gameUserRepository.saveAndFlush(gameUser); + + // Get the gameUser + restGameUserMockMvc.perform(get("/api/game-users/{id}", gameUser.getId())) + .andExpect(status().isOk()) + .andExpect(content().contentType(MediaType.APPLICATION_JSON_VALUE)) + .andExpect(jsonPath("$.id").value(gameUser.getId().intValue())) + .andExpect(jsonPath("$.username").value(DEFAULT_USERNAME)) + .andExpect(jsonPath("$.password").value(DEFAULT_PASSWORD)); + } + + @Test + @Transactional + public void getNonExistingGameUser() throws Exception { + // Get the gameUser + restGameUserMockMvc.perform(get("/api/game-users/{id}", Long.MAX_VALUE)) + .andExpect(status().isNotFound()); + } + + @Test + @Transactional + public void updateGameUser() throws Exception { + // Initialize the database + gameUserRepository.saveAndFlush(gameUser); + + int databaseSizeBeforeUpdate = gameUserRepository.findAll().size(); + + // Update the gameUser + GameUser updatedGameUser = gameUserRepository.findById(gameUser.getId()).get(); + // Disconnect from session so that the updates on updatedGameUser are not directly saved in db + em.detach(updatedGameUser); + updatedGameUser + .username(UPDATED_USERNAME) + .password(UPDATED_PASSWORD); + + restGameUserMockMvc.perform(put("/api/game-users") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(updatedGameUser))) + .andExpect(status().isOk()); + + // Validate the GameUser in the database + List gameUserList = gameUserRepository.findAll(); + assertThat(gameUserList).hasSize(databaseSizeBeforeUpdate); + GameUser testGameUser = gameUserList.get(gameUserList.size() - 1); + assertThat(testGameUser.getUsername()).isEqualTo(UPDATED_USERNAME); + assertThat(testGameUser.getPassword()).isEqualTo(UPDATED_PASSWORD); + } + + @Test + @Transactional + public void updateNonExistingGameUser() throws Exception { + int databaseSizeBeforeUpdate = gameUserRepository.findAll().size(); + + // Create the GameUser + + // If the entity doesn't have an ID, it will throw BadRequestAlertException + restGameUserMockMvc.perform(put("/api/game-users") + .contentType(MediaType.APPLICATION_JSON) + .content(TestUtil.convertObjectToJsonBytes(gameUser))) + .andExpect(status().isBadRequest()); + + // Validate the GameUser in the database + List gameUserList = gameUserRepository.findAll(); + assertThat(gameUserList).hasSize(databaseSizeBeforeUpdate); + } + + @Test + @Transactional + public void deleteGameUser() throws Exception { + // Initialize the database + gameUserRepository.saveAndFlush(gameUser); + + int databaseSizeBeforeDelete = gameUserRepository.findAll().size(); + + // Delete the gameUser + restGameUserMockMvc.perform(delete("/api/game-users/{id}", gameUser.getId()) + .accept(MediaType.APPLICATION_JSON)) + .andExpect(status().isNoContent()); + + // Validate the database contains one less item + List gameUserList = gameUserRepository.findAll(); + assertThat(gameUserList).hasSize(databaseSizeBeforeDelete - 1); + } +} diff --git a/src/test/javascript/spec/app/entities/game-commission/game-commission-delete-dialog.component.spec.ts b/src/test/javascript/spec/app/entities/game-commission/game-commission-delete-dialog.component.spec.ts new file mode 100644 index 0000000..54e43e1 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-commission/game-commission-delete-dialog.component.spec.ts @@ -0,0 +1,65 @@ +import { ComponentFixture, TestBed, inject, fakeAsync, tick } from '@angular/core/testing'; +import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap'; +import { of } from 'rxjs'; +import { JhiEventManager } from 'ng-jhipster'; + +import { AdminTestModule } from '../../../test.module'; +import { MockEventManager } from '../../../helpers/mock-event-manager.service'; +import { MockActiveModal } from '../../../helpers/mock-active-modal.service'; +import { GameCommissionDeleteDialogComponent } from 'app/entities/game-commission/game-commission-delete-dialog.component'; +import { GameCommissionService } from 'app/entities/game-commission/game-commission.service'; + +describe('Component Tests', () => { + describe('GameCommission Management Delete Component', () => { + let comp: GameCommissionDeleteDialogComponent; + let fixture: ComponentFixture; + let service: GameCommissionService; + let mockEventManager: MockEventManager; + let mockActiveModal: MockActiveModal; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameCommissionDeleteDialogComponent] + }) + .overrideTemplate(GameCommissionDeleteDialogComponent, '') + .compileComponents(); + fixture = TestBed.createComponent(GameCommissionDeleteDialogComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameCommissionService); + mockEventManager = TestBed.get(JhiEventManager); + mockActiveModal = TestBed.get(NgbActiveModal); + }); + + describe('confirmDelete', () => { + it('Should call delete service on confirmDelete', inject( + [], + fakeAsync(() => { + // GIVEN + spyOn(service, 'delete').and.returnValue(of({})); + + // WHEN + comp.confirmDelete(123); + tick(); + + // THEN + expect(service.delete).toHaveBeenCalledWith(123); + expect(mockActiveModal.closeSpy).toHaveBeenCalled(); + expect(mockEventManager.broadcastSpy).toHaveBeenCalled(); + }) + )); + + it('Should not call delete service on clear', () => { + // GIVEN + spyOn(service, 'delete'); + + // WHEN + comp.cancel(); + + // THEN + expect(service.delete).not.toHaveBeenCalled(); + expect(mockActiveModal.dismissSpy).toHaveBeenCalled(); + }); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-commission/game-commission-detail.component.spec.ts b/src/test/javascript/spec/app/entities/game-commission/game-commission-detail.component.spec.ts new file mode 100644 index 0000000..d9e3389 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-commission/game-commission-detail.component.spec.ts @@ -0,0 +1,37 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { ActivatedRoute } from '@angular/router'; +import { of } from 'rxjs'; + +import { AdminTestModule } from '../../../test.module'; +import { GameCommissionDetailComponent } from 'app/entities/game-commission/game-commission-detail.component'; +import { GameCommission } from 'app/shared/model/game-commission.model'; + +describe('Component Tests', () => { + describe('GameCommission Management Detail Component', () => { + let comp: GameCommissionDetailComponent; + let fixture: ComponentFixture; + const route = ({ data: of({ gameCommission: new GameCommission(123) }) } as any) as ActivatedRoute; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameCommissionDetailComponent], + providers: [{ provide: ActivatedRoute, useValue: route }] + }) + .overrideTemplate(GameCommissionDetailComponent, '') + .compileComponents(); + fixture = TestBed.createComponent(GameCommissionDetailComponent); + comp = fixture.componentInstance; + }); + + describe('OnInit', () => { + it('Should load gameCommission on init', () => { + // WHEN + comp.ngOnInit(); + + // THEN + expect(comp.gameCommission).toEqual(jasmine.objectContaining({ id: 123 })); + }); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-commission/game-commission-update.component.spec.ts b/src/test/javascript/spec/app/entities/game-commission/game-commission-update.component.spec.ts new file mode 100644 index 0000000..0ac7062 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-commission/game-commission-update.component.spec.ts @@ -0,0 +1,61 @@ +import { ComponentFixture, TestBed, fakeAsync, tick } from '@angular/core/testing'; +import { HttpResponse } from '@angular/common/http'; +import { FormBuilder } from '@angular/forms'; +import { of } from 'rxjs'; + +import { AdminTestModule } from '../../../test.module'; +import { GameCommissionUpdateComponent } from 'app/entities/game-commission/game-commission-update.component'; +import { GameCommissionService } from 'app/entities/game-commission/game-commission.service'; +import { GameCommission } from 'app/shared/model/game-commission.model'; + +describe('Component Tests', () => { + describe('GameCommission Management Update Component', () => { + let comp: GameCommissionUpdateComponent; + let fixture: ComponentFixture; + let service: GameCommissionService; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameCommissionUpdateComponent], + providers: [FormBuilder] + }) + .overrideTemplate(GameCommissionUpdateComponent, '') + .compileComponents(); + + fixture = TestBed.createComponent(GameCommissionUpdateComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameCommissionService); + }); + + describe('save', () => { + it('Should call update service on save for existing entity', fakeAsync(() => { + // GIVEN + const entity = new GameCommission(123); + spyOn(service, 'update').and.returnValue(of(new HttpResponse({ body: entity }))); + comp.updateForm(entity); + // WHEN + comp.save(); + tick(); // simulate async + + // THEN + expect(service.update).toHaveBeenCalledWith(entity); + expect(comp.isSaving).toEqual(false); + })); + + it('Should call create service on save for new entity', fakeAsync(() => { + // GIVEN + const entity = new GameCommission(); + spyOn(service, 'create').and.returnValue(of(new HttpResponse({ body: entity }))); + comp.updateForm(entity); + // WHEN + comp.save(); + tick(); // simulate async + + // THEN + expect(service.create).toHaveBeenCalledWith(entity); + expect(comp.isSaving).toEqual(false); + })); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-commission/game-commission.component.spec.ts b/src/test/javascript/spec/app/entities/game-commission/game-commission.component.spec.ts new file mode 100644 index 0000000..6d1d005 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-commission/game-commission.component.spec.ts @@ -0,0 +1,49 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { of } from 'rxjs'; +import { HttpHeaders, HttpResponse } from '@angular/common/http'; + +import { AdminTestModule } from '../../../test.module'; +import { GameCommissionComponent } from 'app/entities/game-commission/game-commission.component'; +import { GameCommissionService } from 'app/entities/game-commission/game-commission.service'; +import { GameCommission } from 'app/shared/model/game-commission.model'; + +describe('Component Tests', () => { + describe('GameCommission Management Component', () => { + let comp: GameCommissionComponent; + let fixture: ComponentFixture; + let service: GameCommissionService; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameCommissionComponent] + }) + .overrideTemplate(GameCommissionComponent, '') + .compileComponents(); + + fixture = TestBed.createComponent(GameCommissionComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameCommissionService); + }); + + it('Should call load all on init', () => { + // GIVEN + const headers = new HttpHeaders().append('link', 'link;link'); + spyOn(service, 'query').and.returnValue( + of( + new HttpResponse({ + body: [new GameCommission(123)], + headers + }) + ) + ); + + // WHEN + comp.ngOnInit(); + + // THEN + expect(service.query).toHaveBeenCalled(); + expect(comp.gameCommissions && comp.gameCommissions[0]).toEqual(jasmine.objectContaining({ id: 123 })); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-commission/game-commission.service.spec.ts b/src/test/javascript/spec/app/entities/game-commission/game-commission.service.spec.ts new file mode 100644 index 0000000..e7b5e85 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-commission/game-commission.service.spec.ts @@ -0,0 +1,102 @@ +import { TestBed, getTestBed } from '@angular/core/testing'; +import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing'; +import { GameCommissionService } from 'app/entities/game-commission/game-commission.service'; +import { IGameCommission, GameCommission } from 'app/shared/model/game-commission.model'; + +describe('Service Tests', () => { + describe('GameCommission Service', () => { + let injector: TestBed; + let service: GameCommissionService; + let httpMock: HttpTestingController; + let elemDefault: IGameCommission; + let expectedResult: IGameCommission | IGameCommission[] | boolean | null; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [HttpClientTestingModule] + }); + expectedResult = null; + injector = getTestBed(); + service = injector.get(GameCommissionService); + httpMock = injector.get(HttpTestingController); + + elemDefault = new GameCommission(0, 0); + }); + + describe('Service methods', () => { + it('should find an element', () => { + const returnedFromService = Object.assign({}, elemDefault); + + service.find(123).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'GET' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(elemDefault); + }); + + it('should create a GameCommission', () => { + const returnedFromService = Object.assign( + { + id: 0 + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.create(new GameCommission()).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'POST' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(expected); + }); + + it('should update a GameCommission', () => { + const returnedFromService = Object.assign( + { + commission: 1 + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.update(expected).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'PUT' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(expected); + }); + + it('should return a list of GameCommission', () => { + const returnedFromService = Object.assign( + { + commission: 1 + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.query().subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'GET' }); + req.flush([returnedFromService]); + httpMock.verify(); + expect(expectedResult).toContainEqual(expected); + }); + + it('should delete a GameCommission', () => { + service.delete(123).subscribe(resp => (expectedResult = resp.ok)); + + const req = httpMock.expectOne({ method: 'DELETE' }); + req.flush({ status: 200 }); + expect(expectedResult); + }); + }); + + afterEach(() => { + httpMock.verify(); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-user/game-user-delete-dialog.component.spec.ts b/src/test/javascript/spec/app/entities/game-user/game-user-delete-dialog.component.spec.ts new file mode 100644 index 0000000..8db17bf --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-user/game-user-delete-dialog.component.spec.ts @@ -0,0 +1,65 @@ +import { ComponentFixture, TestBed, inject, fakeAsync, tick } from '@angular/core/testing'; +import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap'; +import { of } from 'rxjs'; +import { JhiEventManager } from 'ng-jhipster'; + +import { AdminTestModule } from '../../../test.module'; +import { MockEventManager } from '../../../helpers/mock-event-manager.service'; +import { MockActiveModal } from '../../../helpers/mock-active-modal.service'; +import { GameUserDeleteDialogComponent } from 'app/entities/game-user/game-user-delete-dialog.component'; +import { GameUserService } from 'app/entities/game-user/game-user.service'; + +describe('Component Tests', () => { + describe('GameUser Management Delete Component', () => { + let comp: GameUserDeleteDialogComponent; + let fixture: ComponentFixture; + let service: GameUserService; + let mockEventManager: MockEventManager; + let mockActiveModal: MockActiveModal; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameUserDeleteDialogComponent] + }) + .overrideTemplate(GameUserDeleteDialogComponent, '') + .compileComponents(); + fixture = TestBed.createComponent(GameUserDeleteDialogComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameUserService); + mockEventManager = TestBed.get(JhiEventManager); + mockActiveModal = TestBed.get(NgbActiveModal); + }); + + describe('confirmDelete', () => { + it('Should call delete service on confirmDelete', inject( + [], + fakeAsync(() => { + // GIVEN + spyOn(service, 'delete').and.returnValue(of({})); + + // WHEN + comp.confirmDelete(123); + tick(); + + // THEN + expect(service.delete).toHaveBeenCalledWith(123); + expect(mockActiveModal.closeSpy).toHaveBeenCalled(); + expect(mockEventManager.broadcastSpy).toHaveBeenCalled(); + }) + )); + + it('Should not call delete service on clear', () => { + // GIVEN + spyOn(service, 'delete'); + + // WHEN + comp.cancel(); + + // THEN + expect(service.delete).not.toHaveBeenCalled(); + expect(mockActiveModal.dismissSpy).toHaveBeenCalled(); + }); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-user/game-user-detail.component.spec.ts b/src/test/javascript/spec/app/entities/game-user/game-user-detail.component.spec.ts new file mode 100644 index 0000000..c3e3878 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-user/game-user-detail.component.spec.ts @@ -0,0 +1,37 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { ActivatedRoute } from '@angular/router'; +import { of } from 'rxjs'; + +import { AdminTestModule } from '../../../test.module'; +import { GameUserDetailComponent } from 'app/entities/game-user/game-user-detail.component'; +import { GameUser } from 'app/shared/model/game-user.model'; + +describe('Component Tests', () => { + describe('GameUser Management Detail Component', () => { + let comp: GameUserDetailComponent; + let fixture: ComponentFixture; + const route = ({ data: of({ gameUser: new GameUser(123) }) } as any) as ActivatedRoute; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameUserDetailComponent], + providers: [{ provide: ActivatedRoute, useValue: route }] + }) + .overrideTemplate(GameUserDetailComponent, '') + .compileComponents(); + fixture = TestBed.createComponent(GameUserDetailComponent); + comp = fixture.componentInstance; + }); + + describe('OnInit', () => { + it('Should load gameUser on init', () => { + // WHEN + comp.ngOnInit(); + + // THEN + expect(comp.gameUser).toEqual(jasmine.objectContaining({ id: 123 })); + }); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-user/game-user-update.component.spec.ts b/src/test/javascript/spec/app/entities/game-user/game-user-update.component.spec.ts new file mode 100644 index 0000000..0937c2b --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-user/game-user-update.component.spec.ts @@ -0,0 +1,61 @@ +import { ComponentFixture, TestBed, fakeAsync, tick } from '@angular/core/testing'; +import { HttpResponse } from '@angular/common/http'; +import { FormBuilder } from '@angular/forms'; +import { of } from 'rxjs'; + +import { AdminTestModule } from '../../../test.module'; +import { GameUserUpdateComponent } from 'app/entities/game-user/game-user-update.component'; +import { GameUserService } from 'app/entities/game-user/game-user.service'; +import { GameUser } from 'app/shared/model/game-user.model'; + +describe('Component Tests', () => { + describe('GameUser Management Update Component', () => { + let comp: GameUserUpdateComponent; + let fixture: ComponentFixture; + let service: GameUserService; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameUserUpdateComponent], + providers: [FormBuilder] + }) + .overrideTemplate(GameUserUpdateComponent, '') + .compileComponents(); + + fixture = TestBed.createComponent(GameUserUpdateComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameUserService); + }); + + describe('save', () => { + it('Should call update service on save for existing entity', fakeAsync(() => { + // GIVEN + const entity = new GameUser(123); + spyOn(service, 'update').and.returnValue(of(new HttpResponse({ body: entity }))); + comp.updateForm(entity); + // WHEN + comp.save(); + tick(); // simulate async + + // THEN + expect(service.update).toHaveBeenCalledWith(entity); + expect(comp.isSaving).toEqual(false); + })); + + it('Should call create service on save for new entity', fakeAsync(() => { + // GIVEN + const entity = new GameUser(); + spyOn(service, 'create').and.returnValue(of(new HttpResponse({ body: entity }))); + comp.updateForm(entity); + // WHEN + comp.save(); + tick(); // simulate async + + // THEN + expect(service.create).toHaveBeenCalledWith(entity); + expect(comp.isSaving).toEqual(false); + })); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-user/game-user.component.spec.ts b/src/test/javascript/spec/app/entities/game-user/game-user.component.spec.ts new file mode 100644 index 0000000..a0823e2 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-user/game-user.component.spec.ts @@ -0,0 +1,49 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { of } from 'rxjs'; +import { HttpHeaders, HttpResponse } from '@angular/common/http'; + +import { AdminTestModule } from '../../../test.module'; +import { GameUserComponent } from 'app/entities/game-user/game-user.component'; +import { GameUserService } from 'app/entities/game-user/game-user.service'; +import { GameUser } from 'app/shared/model/game-user.model'; + +describe('Component Tests', () => { + describe('GameUser Management Component', () => { + let comp: GameUserComponent; + let fixture: ComponentFixture; + let service: GameUserService; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameUserComponent] + }) + .overrideTemplate(GameUserComponent, '') + .compileComponents(); + + fixture = TestBed.createComponent(GameUserComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameUserService); + }); + + it('Should call load all on init', () => { + // GIVEN + const headers = new HttpHeaders().append('link', 'link;link'); + spyOn(service, 'query').and.returnValue( + of( + new HttpResponse({ + body: [new GameUser(123)], + headers + }) + ) + ); + + // WHEN + comp.ngOnInit(); + + // THEN + expect(service.query).toHaveBeenCalled(); + expect(comp.gameUsers && comp.gameUsers[0]).toEqual(jasmine.objectContaining({ id: 123 })); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game-user/game-user.service.spec.ts b/src/test/javascript/spec/app/entities/game-user/game-user.service.spec.ts new file mode 100644 index 0000000..cfd0bd8 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game-user/game-user.service.spec.ts @@ -0,0 +1,104 @@ +import { TestBed, getTestBed } from '@angular/core/testing'; +import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing'; +import { GameUserService } from 'app/entities/game-user/game-user.service'; +import { IGameUser, GameUser } from 'app/shared/model/game-user.model'; + +describe('Service Tests', () => { + describe('GameUser Service', () => { + let injector: TestBed; + let service: GameUserService; + let httpMock: HttpTestingController; + let elemDefault: IGameUser; + let expectedResult: IGameUser | IGameUser[] | boolean | null; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [HttpClientTestingModule] + }); + expectedResult = null; + injector = getTestBed(); + service = injector.get(GameUserService); + httpMock = injector.get(HttpTestingController); + + elemDefault = new GameUser(0, 'AAAAAAA', 'AAAAAAA'); + }); + + describe('Service methods', () => { + it('should find an element', () => { + const returnedFromService = Object.assign({}, elemDefault); + + service.find(123).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'GET' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(elemDefault); + }); + + it('should create a GameUser', () => { + const returnedFromService = Object.assign( + { + id: 0 + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.create(new GameUser()).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'POST' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(expected); + }); + + it('should update a GameUser', () => { + const returnedFromService = Object.assign( + { + username: 'BBBBBB', + password: 'BBBBBB' + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.update(expected).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'PUT' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(expected); + }); + + it('should return a list of GameUser', () => { + const returnedFromService = Object.assign( + { + username: 'BBBBBB', + password: 'BBBBBB' + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.query().subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'GET' }); + req.flush([returnedFromService]); + httpMock.verify(); + expect(expectedResult).toContainEqual(expected); + }); + + it('should delete a GameUser', () => { + service.delete(123).subscribe(resp => (expectedResult = resp.ok)); + + const req = httpMock.expectOne({ method: 'DELETE' }); + req.flush({ status: 200 }); + expect(expectedResult); + }); + }); + + afterEach(() => { + httpMock.verify(); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game/game-delete-dialog.component.spec.ts b/src/test/javascript/spec/app/entities/game/game-delete-dialog.component.spec.ts new file mode 100644 index 0000000..d847d07 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game/game-delete-dialog.component.spec.ts @@ -0,0 +1,65 @@ +import { ComponentFixture, TestBed, inject, fakeAsync, tick } from '@angular/core/testing'; +import { NgbActiveModal } from '@ng-bootstrap/ng-bootstrap'; +import { of } from 'rxjs'; +import { JhiEventManager } from 'ng-jhipster'; + +import { AdminTestModule } from '../../../test.module'; +import { MockEventManager } from '../../../helpers/mock-event-manager.service'; +import { MockActiveModal } from '../../../helpers/mock-active-modal.service'; +import { GameDeleteDialogComponent } from 'app/entities/game/game-delete-dialog.component'; +import { GameService } from 'app/entities/game/game.service'; + +describe('Component Tests', () => { + describe('Game Management Delete Component', () => { + let comp: GameDeleteDialogComponent; + let fixture: ComponentFixture; + let service: GameService; + let mockEventManager: MockEventManager; + let mockActiveModal: MockActiveModal; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameDeleteDialogComponent] + }) + .overrideTemplate(GameDeleteDialogComponent, '') + .compileComponents(); + fixture = TestBed.createComponent(GameDeleteDialogComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameService); + mockEventManager = TestBed.get(JhiEventManager); + mockActiveModal = TestBed.get(NgbActiveModal); + }); + + describe('confirmDelete', () => { + it('Should call delete service on confirmDelete', inject( + [], + fakeAsync(() => { + // GIVEN + spyOn(service, 'delete').and.returnValue(of({})); + + // WHEN + comp.confirmDelete(123); + tick(); + + // THEN + expect(service.delete).toHaveBeenCalledWith(123); + expect(mockActiveModal.closeSpy).toHaveBeenCalled(); + expect(mockEventManager.broadcastSpy).toHaveBeenCalled(); + }) + )); + + it('Should not call delete service on clear', () => { + // GIVEN + spyOn(service, 'delete'); + + // WHEN + comp.cancel(); + + // THEN + expect(service.delete).not.toHaveBeenCalled(); + expect(mockActiveModal.dismissSpy).toHaveBeenCalled(); + }); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game/game-detail.component.spec.ts b/src/test/javascript/spec/app/entities/game/game-detail.component.spec.ts new file mode 100644 index 0000000..f32cdd9 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game/game-detail.component.spec.ts @@ -0,0 +1,37 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { ActivatedRoute } from '@angular/router'; +import { of } from 'rxjs'; + +import { AdminTestModule } from '../../../test.module'; +import { GameDetailComponent } from 'app/entities/game/game-detail.component'; +import { Game } from 'app/shared/model/game.model'; + +describe('Component Tests', () => { + describe('Game Management Detail Component', () => { + let comp: GameDetailComponent; + let fixture: ComponentFixture; + const route = ({ data: of({ game: new Game(123) }) } as any) as ActivatedRoute; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameDetailComponent], + providers: [{ provide: ActivatedRoute, useValue: route }] + }) + .overrideTemplate(GameDetailComponent, '') + .compileComponents(); + fixture = TestBed.createComponent(GameDetailComponent); + comp = fixture.componentInstance; + }); + + describe('OnInit', () => { + it('Should load game on init', () => { + // WHEN + comp.ngOnInit(); + + // THEN + expect(comp.game).toEqual(jasmine.objectContaining({ id: 123 })); + }); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game/game-update.component.spec.ts b/src/test/javascript/spec/app/entities/game/game-update.component.spec.ts new file mode 100644 index 0000000..790d93a --- /dev/null +++ b/src/test/javascript/spec/app/entities/game/game-update.component.spec.ts @@ -0,0 +1,61 @@ +import { ComponentFixture, TestBed, fakeAsync, tick } from '@angular/core/testing'; +import { HttpResponse } from '@angular/common/http'; +import { FormBuilder } from '@angular/forms'; +import { of } from 'rxjs'; + +import { AdminTestModule } from '../../../test.module'; +import { GameUpdateComponent } from 'app/entities/game/game-update.component'; +import { GameService } from 'app/entities/game/game.service'; +import { Game } from 'app/shared/model/game.model'; + +describe('Component Tests', () => { + describe('Game Management Update Component', () => { + let comp: GameUpdateComponent; + let fixture: ComponentFixture; + let service: GameService; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameUpdateComponent], + providers: [FormBuilder] + }) + .overrideTemplate(GameUpdateComponent, '') + .compileComponents(); + + fixture = TestBed.createComponent(GameUpdateComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameService); + }); + + describe('save', () => { + it('Should call update service on save for existing entity', fakeAsync(() => { + // GIVEN + const entity = new Game(123); + spyOn(service, 'update').and.returnValue(of(new HttpResponse({ body: entity }))); + comp.updateForm(entity); + // WHEN + comp.save(); + tick(); // simulate async + + // THEN + expect(service.update).toHaveBeenCalledWith(entity); + expect(comp.isSaving).toEqual(false); + })); + + it('Should call create service on save for new entity', fakeAsync(() => { + // GIVEN + const entity = new Game(); + spyOn(service, 'create').and.returnValue(of(new HttpResponse({ body: entity }))); + comp.updateForm(entity); + // WHEN + comp.save(); + tick(); // simulate async + + // THEN + expect(service.create).toHaveBeenCalledWith(entity); + expect(comp.isSaving).toEqual(false); + })); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game/game.component.spec.ts b/src/test/javascript/spec/app/entities/game/game.component.spec.ts new file mode 100644 index 0000000..bfa6dca --- /dev/null +++ b/src/test/javascript/spec/app/entities/game/game.component.spec.ts @@ -0,0 +1,49 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; +import { of } from 'rxjs'; +import { HttpHeaders, HttpResponse } from '@angular/common/http'; + +import { AdminTestModule } from '../../../test.module'; +import { GameComponent } from 'app/entities/game/game.component'; +import { GameService } from 'app/entities/game/game.service'; +import { Game } from 'app/shared/model/game.model'; + +describe('Component Tests', () => { + describe('Game Management Component', () => { + let comp: GameComponent; + let fixture: ComponentFixture; + let service: GameService; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [AdminTestModule], + declarations: [GameComponent] + }) + .overrideTemplate(GameComponent, '') + .compileComponents(); + + fixture = TestBed.createComponent(GameComponent); + comp = fixture.componentInstance; + service = fixture.debugElement.injector.get(GameService); + }); + + it('Should call load all on init', () => { + // GIVEN + const headers = new HttpHeaders().append('link', 'link;link'); + spyOn(service, 'query').and.returnValue( + of( + new HttpResponse({ + body: [new Game(123)], + headers + }) + ) + ); + + // WHEN + comp.ngOnInit(); + + // THEN + expect(service.query).toHaveBeenCalled(); + expect(comp.games && comp.games[0]).toEqual(jasmine.objectContaining({ id: 123 })); + }); + }); +}); diff --git a/src/test/javascript/spec/app/entities/game/game.service.spec.ts b/src/test/javascript/spec/app/entities/game/game.service.spec.ts new file mode 100644 index 0000000..8210173 --- /dev/null +++ b/src/test/javascript/spec/app/entities/game/game.service.spec.ts @@ -0,0 +1,102 @@ +import { TestBed, getTestBed } from '@angular/core/testing'; +import { HttpClientTestingModule, HttpTestingController } from '@angular/common/http/testing'; +import { GameService } from 'app/entities/game/game.service'; +import { IGame, Game } from 'app/shared/model/game.model'; + +describe('Service Tests', () => { + describe('Game Service', () => { + let injector: TestBed; + let service: GameService; + let httpMock: HttpTestingController; + let elemDefault: IGame; + let expectedResult: IGame | IGame[] | boolean | null; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [HttpClientTestingModule] + }); + expectedResult = null; + injector = getTestBed(); + service = injector.get(GameService); + httpMock = injector.get(HttpTestingController); + + elemDefault = new Game(0, 'AAAAAAA'); + }); + + describe('Service methods', () => { + it('should find an element', () => { + const returnedFromService = Object.assign({}, elemDefault); + + service.find(123).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'GET' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(elemDefault); + }); + + it('should create a Game', () => { + const returnedFromService = Object.assign( + { + id: 0 + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.create(new Game()).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'POST' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(expected); + }); + + it('should update a Game', () => { + const returnedFromService = Object.assign( + { + name: 'BBBBBB' + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.update(expected).subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'PUT' }); + req.flush(returnedFromService); + expect(expectedResult).toMatchObject(expected); + }); + + it('should return a list of Game', () => { + const returnedFromService = Object.assign( + { + name: 'BBBBBB' + }, + elemDefault + ); + + const expected = Object.assign({}, returnedFromService); + + service.query().subscribe(resp => (expectedResult = resp.body)); + + const req = httpMock.expectOne({ method: 'GET' }); + req.flush([returnedFromService]); + httpMock.verify(); + expect(expectedResult).toContainEqual(expected); + }); + + it('should delete a Game', () => { + service.delete(123).subscribe(resp => (expectedResult = resp.ok)); + + const req = httpMock.expectOne({ method: 'DELETE' }); + req.flush({ status: 200 }); + expect(expectedResult); + }); + }); + + afterEach(() => { + httpMock.verify(); + }); + }); +});