GitXplorerGitXplorer
k

mybatis-spring-boot-jpetstore

public
89 stars
82 forks
15 issues

Commits

List of commits on branch master.
Verified
20d013a1e050c50e08c0eaf6698fe555e1fd5bc8

Merge pull request #276 from kazuki43zoo/dependabot/maven/org.apache.groovy-groovy-4.0.3

kkazuki43zoo committed 3 years ago
Verified
a5142c0ea1a05abade1dc63c8ff3448352ea5586

Merge pull request #279 from kazuki43zoo/dependabot/maven/com.codeborne-selenide-6.6.1

kkazuki43zoo committed 3 years ago
Verified
a1f9831c485a04d779f9f49392130deeddf05e01

Bump selenide from 6.5.0 to 6.6.1

ddependabot[bot] committed 3 years ago
Verified
3dbeb526e9c534382a4c058c971145c538f779cf

Bump groovy from 4.0.2 to 4.0.3

ddependabot[bot] committed 3 years ago
Verified
1b1ce6fb1da0990dbc437ffc0b59ec0bc09c9434

Update README.md [skip ci]

kkazuki43zoo committed 3 years ago
Verified
ccdad841cb3b81320d2ad3994cc59b7a8ed62bbf

Merge pull request #274 from kazuki43zoo/update-selenide

kkazuki43zoo committed 3 years ago

README

The README file for this repository.

mybatis-spring-boot-jpetstore

Java CI Dependency Check Quality Gate Status Coverage

This sample is a web application built on MyBatis, Spring Boot(Spring MVC, Spring Security) and Thymeleaf. This is another implementation of MyBatis JPetStore sample application (https://github.com/mybatis/jpetstore-6).

Original application is available for downloading in the downloads section of MyBatis project site. In this section, we will walk through this sample to understand how is it built and learn how to run it.

Note

This sample application is under development. If you found an issue, please report from here.

Requirements

  • Java 8+ (JDK 1.8+)

Stacks

  • MyBatis Spring Boot Starter 2.2 (MyBatis 3.5, MyBatis Spring 2.0)
  • Spring Boot 2.7 (Spring Framework 5.3, Spring Security 5.7)
  • Thymeleaf 3.0
  • Hibernate Validator 6.2 (Bean Validation 2.0)
  • HSQLDB 2.5 (Embed Database)
  • Flyway 8.5 (DB Migration)
  • Tomcat 9.0 (Embed Application Server)
  • Groovy 4.0 (Use multiple line string on MyBatis Mapper method)
  • Lombok 1.18
  • Selenide 6.5
  • Selenium 4.1
  • etc ...

Run using Maven command

  • Clone this repository

    $ git clone https://github.com/kazuki43zoo/mybatis-spring-boot-jpetstore.git
    
  • Run a web application using the spring-boot-plugin

    $ cd mybatis-spring-boot-jpetstore.git
    $ ./mvnw clean spring-boot:run
    

Run using java command

  • Build a jar file

    $ ./mvnw clean package -DskipTests=true
    
  • Run java command

    $ java -jar target/mybatis-spring-boot-jpetstore-2.0.0-SNAPSHOT.jar
    

Perform integration test using Maven command

Perform integration tests for screen transition.

$ ./mvnw clean test

Run on IDEs (Note)

This sample use the Lombok to generate setter method, getter method and constructor. If this sample application run on your IDE, please install the Lombok. (see https://projectlombok.org/download.html)

And this application use the groovy language to use multiple line string on MyBatis Mapper method. If this sample application run on your IDE, please convert to groovy project and add src/main/groovy into source path. And if you use a STS(or Eclipse), please install the Groovy Eclipse plugin. About how install the Groovy Eclipse, please see as follow:

e.g.) multiple line string on MyBatis Mapper method

@Mapper
@CacheNamespace
interface CategoryMapper {

    @Select('''
        SELECT
            CATID AS categoryId,
            NAME,
            DESCN AS description
        FROM
            CATEGORY
        WHERE
            CATID = #{categoryId}
    ''')
    Category getCategory(String categoryId)

}

Access to the index page

http://localhost:8080/

Index Screen

Catalog Screen

Default active accounts (ID/PASSWORD)

  • j2ee/j2ee
  • ACID/ACID

Data Store

In this application, application data stored in filesystem files.

$HOME
  └── db
      + jpetstore.script
      + jpetstore.properties

Project Structure

Project structure of this sample application is as follow:

.
└── src
    └── main
        ├── groovy
        │   └── com
        │       └── kazuki43zoo
        │           └── jpetstore
        │               └── mapper         // Store mapper interfaces
        ├── java
        │   └── com
        │       └── kazuki43zoo
        │           └── jpetstore
        │               ├── component      // Store general component classes
        │               │   ├── event
        │               │   ├── exception
        │               │   ├── message
        │               │   └── validation
        │               ├── config         // Store configuration classes
        │               ├── domain         // Store domain objects
        │               ├── service        // Store service classes
        │               └── ui             // Store classes that depends user interface
        │                   └── controller // Store controller classes
        └── resources
            ├── db                         // Store sql files for Flyway
            │   └── migration
            ├── static                     // Store static web resource files
            │   ├── css
            │   └── images
            └── templates                  // Store view template files for Thymeleaf
                ├── account
                ├── auth
                ├── cart
                ├── catalog
                ├── error
                └── order