Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
S
spring-boot-reactive-mongodb-example
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Galib Shaheed Khan
spring-boot-reactive-mongodb-example
Commits
0cb10640
Commit
0cb10640
authored
2 years ago
by
gkhan
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
spring with flux and mongodb code added
parent
1d0cdf42
Changes
17
Show whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
1131 additions
and
0 deletions
+1131
-0
.project
.project
+23
-0
mvnw
mvnw
+316
-0
mvnw.cmd
mvnw.cmd
+188
-0
pom.xml
pom.xml
+74
-0
SpringReactiveMongoCurdApplication.java
...om/nisum/reactive/SpringReactiveMongoCurdApplication.java
+13
-0
ProductController.java
...java/com/nisum/reactive/controller/ProductController.java
+58
-0
ProductDto.java
src/main/java/com/nisum/reactive/dto/ProductDto.java
+16
-0
Product.java
src/main/java/com/nisum/reactive/entity/Product.java
+22
-0
ProductRepository.java
...java/com/nisum/reactive/repository/ProductRepository.java
+15
-0
ProductService.java
src/main/java/com/nisum/reactive/service/ProductService.java
+47
-0
AppUtils.java
src/main/java/com/nisum/reactive/util/AppUtils.java
+22
-0
application.properties
src/main/resources/application.properties
+5
-0
application.yml
src/main/resources/application.yml
+10
-0
ProductServiceTest.java
src/test/java/com/nisum/reactive/ProductServiceTest.java
+71
-0
SpringBootApplicationTest.java
...st/java/com/nisum/reactive/SpringBootApplicationTest.java
+98
-0
SpringBootReactiveControllerTest.java
.../com/nisum/reactive/SpringBootReactiveControllerTest.java
+44
-0
SpringReactiveMongoCurdApplicationTests.java
...sum/reactive/SpringReactiveMongoCurdApplicationTests.java
+109
-0
No files found.
.project
0 → 100644
View file @
0cb10640
<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
<name>
spring-reactive-mongo-curd
</name>
<comment></comment>
<projects>
</projects>
<buildSpec>
<buildCommand>
<name>
org.eclipse.jdt.core.javabuilder
</name>
<arguments>
</arguments>
</buildCommand>
<buildCommand>
<name>
org.eclipse.m2e.core.maven2Builder
</name>
<arguments>
</arguments>
</buildCommand>
</buildSpec>
<natures>
<nature>
org.eclipse.jdt.core.javanature
</nature>
<nature>
org.eclipse.m2e.core.maven2Nature
</nature>
</natures>
</projectDescription>
This diff is collapsed.
Click to expand it.
mvnw
0 → 100644
View file @
0cb10640
#!/bin/sh
# ----------------------------------------------------------------------------
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
# https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
# ----------------------------------------------------------------------------
# ----------------------------------------------------------------------------
# Maven Start Up Batch script
#
# Required ENV vars:
# ------------------
# JAVA_HOME - location of a JDK home dir
#
# Optional ENV vars
# -----------------
# M2_HOME - location of maven2's installed home dir
# MAVEN_OPTS - parameters passed to the Java VM when running Maven
# e.g. to debug Maven itself, use
# set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
# MAVEN_SKIP_RC - flag to disable loading of mavenrc files
# ----------------------------------------------------------------------------
if
[
-z
"
$MAVEN_SKIP_RC
"
]
;
then
if
[
-f
/usr/local/etc/mavenrc
]
;
then
.
/usr/local/etc/mavenrc
fi
if
[
-f
/etc/mavenrc
]
;
then
.
/etc/mavenrc
fi
if
[
-f
"
$HOME
/.mavenrc"
]
;
then
.
"
$HOME
/.mavenrc"
fi
fi
# OS specific support. $var _must_ be set to either true or false.
cygwin
=
false
;
darwin
=
false
;
mingw
=
false
case
"
`
uname
`
"
in
CYGWIN
*
)
cygwin
=
true
;;
MINGW
*
)
mingw
=
true
;;
Darwin
*
)
darwin
=
true
# Use /usr/libexec/java_home if available, otherwise fall back to /Library/Java/Home
# See https://developer.apple.com/library/mac/qa/qa1170/_index.html
if
[
-z
"
$JAVA_HOME
"
]
;
then
if
[
-x
"/usr/libexec/java_home"
]
;
then
export
JAVA_HOME
=
"
`
/usr/libexec/java_home
`
"
else
export
JAVA_HOME
=
"/Library/Java/Home"
fi
fi
;;
esac
if
[
-z
"
$JAVA_HOME
"
]
;
then
if
[
-r
/etc/gentoo-release
]
;
then
JAVA_HOME
=
`
java-config
--jre-home
`
fi
fi
if
[
-z
"
$M2_HOME
"
]
;
then
## resolve links - $0 may be a link to maven's home
PRG
=
"
$0
"
# need this for relative symlinks
while
[
-h
"
$PRG
"
]
;
do
ls
=
`
ls
-ld
"
$PRG
"
`
link
=
`
expr
"
$ls
"
:
'.*-> \(.*\)$'
`
if
expr
"
$link
"
:
'/.*'
>
/dev/null
;
then
PRG
=
"
$link
"
else
PRG
=
"
`
dirname
"
$PRG
"
`
/
$link
"
fi
done
saveddir
=
`
pwd
`
M2_HOME
=
`
dirname
"
$PRG
"
`
/..
# make it fully qualified
M2_HOME
=
`
cd
"
$M2_HOME
"
&&
pwd
`
cd
"
$saveddir
"
# echo Using m2 at $M2_HOME
fi
# For Cygwin, ensure paths are in UNIX format before anything is touched
if
$cygwin
;
then
[
-n
"
$M2_HOME
"
]
&&
M2_HOME
=
`
cygpath
--unix
"
$M2_HOME
"
`
[
-n
"
$JAVA_HOME
"
]
&&
JAVA_HOME
=
`
cygpath
--unix
"
$JAVA_HOME
"
`
[
-n
"
$CLASSPATH
"
]
&&
CLASSPATH
=
`
cygpath
--path
--unix
"
$CLASSPATH
"
`
fi
# For Mingw, ensure paths are in UNIX format before anything is touched
if
$mingw
;
then
[
-n
"
$M2_HOME
"
]
&&
M2_HOME
=
"
`
(
cd
"
$M2_HOME
"
;
pwd
)
`
"
[
-n
"
$JAVA_HOME
"
]
&&
JAVA_HOME
=
"
`
(
cd
"
$JAVA_HOME
"
;
pwd
)
`
"
fi
if
[
-z
"
$JAVA_HOME
"
]
;
then
javaExecutable
=
"
`
which javac
`
"
if
[
-n
"
$javaExecutable
"
]
&&
!
[
"
`
expr
\"
$javaExecutable
\"
:
'\([^ ]*\)'
`
"
=
"no"
]
;
then
# readlink(1) is not available as standard on Solaris 10.
readLink
=
`
which
readlink
`
if
[
!
`
expr
"
$readLink
"
:
'\([^ ]*\)'
`
=
"no"
]
;
then
if
$darwin
;
then
javaHome
=
"
`
dirname
\"
$javaExecutable
\"
`
"
javaExecutable
=
"
`
cd
\"
$javaHome
\"
&&
pwd
-P
`
/javac"
else
javaExecutable
=
"
`
readlink
-f
\"
$javaExecutable
\"
`
"
fi
javaHome
=
"
`
dirname
\"
$javaExecutable
\"
`
"
javaHome
=
`
expr
"
$javaHome
"
:
'\(.*\)/bin'
`
JAVA_HOME
=
"
$javaHome
"
export
JAVA_HOME
fi
fi
fi
if
[
-z
"
$JAVACMD
"
]
;
then
if
[
-n
"
$JAVA_HOME
"
]
;
then
if
[
-x
"
$JAVA_HOME
/jre/sh/java"
]
;
then
# IBM's JDK on AIX uses strange locations for the executables
JAVACMD
=
"
$JAVA_HOME
/jre/sh/java"
else
JAVACMD
=
"
$JAVA_HOME
/bin/java"
fi
else
JAVACMD
=
"
`
\\
unset
-f
command
;
\\
command
-v
java
`
"
fi
fi
if
[
!
-x
"
$JAVACMD
"
]
;
then
echo
"Error: JAVA_HOME is not defined correctly."
>
&2
echo
" We cannot execute
$JAVACMD
"
>
&2
exit
1
fi
if
[
-z
"
$JAVA_HOME
"
]
;
then
echo
"Warning: JAVA_HOME environment variable is not set."
fi
CLASSWORLDS_LAUNCHER
=
org.codehaus.plexus.classworlds.launcher.Launcher
# traverses directory structure from process work directory to filesystem root
# first directory with .mvn subdirectory is considered project base directory
find_maven_basedir
()
{
if
[
-z
"
$1
"
]
then
echo
"Path not specified to find_maven_basedir"
return
1
fi
basedir
=
"
$1
"
wdir
=
"
$1
"
while
[
"
$wdir
"
!=
'/'
]
;
do
if
[
-d
"
$wdir
"
/.mvn
]
;
then
basedir
=
$wdir
break
fi
# workaround for JBEAP-8937 (on Solaris 10/Sparc)
if
[
-d
"
${
wdir
}
"
]
;
then
wdir
=
`
cd
"
$wdir
/.."
;
pwd
`
fi
# end of workaround
done
echo
"
${
basedir
}
"
}
# concatenates all lines of a file
concat_lines
()
{
if
[
-f
"
$1
"
]
;
then
echo
"
$(
tr
-s
'\n'
' '
<
"
$1
"
)
"
fi
}
BASE_DIR
=
`
find_maven_basedir
"
$(
pwd
)
"
`
if
[
-z
"
$BASE_DIR
"
]
;
then
exit
1
;
fi
##########################################################################################
# Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
# This allows using the maven wrapper in projects that prohibit checking in binary data.
##########################################################################################
if
[
-r
"
$BASE_DIR
/.mvn/wrapper/maven-wrapper.jar"
]
;
then
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
"Found .mvn/wrapper/maven-wrapper.jar"
fi
else
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
"Couldn't find .mvn/wrapper/maven-wrapper.jar, downloading it ..."
fi
if
[
-n
"
$MVNW_REPOURL
"
]
;
then
jarUrl
=
"
$MVNW_REPOURL
/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
else
jarUrl
=
"https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
fi
while
IFS
=
"="
read
key value
;
do
case
"
$key
"
in
(
wrapperUrl
)
jarUrl
=
"
$value
"
;
break
;;
esac
done
<
"
$BASE_DIR
/.mvn/wrapper/maven-wrapper.properties"
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
"Downloading from:
$jarUrl
"
fi
wrapperJarPath
=
"
$BASE_DIR
/.mvn/wrapper/maven-wrapper.jar"
if
$cygwin
;
then
wrapperJarPath
=
`
cygpath
--path
--windows
"
$wrapperJarPath
"
`
fi
if
command
-v
wget
>
/dev/null
;
then
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
"Found wget ... using wget"
fi
if
[
-z
"
$MVNW_USERNAME
"
]
||
[
-z
"
$MVNW_PASSWORD
"
]
;
then
wget
"
$jarUrl
"
-O
"
$wrapperJarPath
"
||
rm
-f
"
$wrapperJarPath
"
else
wget
--http-user
=
$MVNW_USERNAME
--http-password
=
$MVNW_PASSWORD
"
$jarUrl
"
-O
"
$wrapperJarPath
"
||
rm
-f
"
$wrapperJarPath
"
fi
elif
command
-v
curl
>
/dev/null
;
then
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
"Found curl ... using curl"
fi
if
[
-z
"
$MVNW_USERNAME
"
]
||
[
-z
"
$MVNW_PASSWORD
"
]
;
then
curl
-o
"
$wrapperJarPath
"
"
$jarUrl
"
-f
else
curl
--user
$MVNW_USERNAME
:
$MVNW_PASSWORD
-o
"
$wrapperJarPath
"
"
$jarUrl
"
-f
fi
else
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
"Falling back to using Java to download"
fi
javaClass
=
"
$BASE_DIR
/.mvn/wrapper/MavenWrapperDownloader.java"
# For Cygwin, switch paths to Windows format before running javac
if
$cygwin
;
then
javaClass
=
`
cygpath
--path
--windows
"
$javaClass
"
`
fi
if
[
-e
"
$javaClass
"
]
;
then
if
[
!
-e
"
$BASE_DIR
/.mvn/wrapper/MavenWrapperDownloader.class"
]
;
then
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
" - Compiling MavenWrapperDownloader.java ..."
fi
# Compiling the Java class
(
"
$JAVA_HOME
/bin/javac"
"
$javaClass
"
)
fi
if
[
-e
"
$BASE_DIR
/.mvn/wrapper/MavenWrapperDownloader.class"
]
;
then
# Running the downloader
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
" - Running MavenWrapperDownloader.java ..."
fi
(
"
$JAVA_HOME
/bin/java"
-cp
.mvn/wrapper MavenWrapperDownloader
"
$MAVEN_PROJECTBASEDIR
"
)
fi
fi
fi
fi
##########################################################################################
# End of extension
##########################################################################################
export
MAVEN_PROJECTBASEDIR
=
${
MAVEN_BASEDIR
:-
"
$BASE_DIR
"
}
if
[
"
$MVNW_VERBOSE
"
=
true
]
;
then
echo
$MAVEN_PROJECTBASEDIR
fi
MAVEN_OPTS
=
"
$(
concat_lines
"
$MAVEN_PROJECTBASEDIR
/.mvn/jvm.config"
)
$MAVEN_OPTS
"
# For Cygwin, switch paths to Windows format before running java
if
$cygwin
;
then
[
-n
"
$M2_HOME
"
]
&&
M2_HOME
=
`
cygpath
--path
--windows
"
$M2_HOME
"
`
[
-n
"
$JAVA_HOME
"
]
&&
JAVA_HOME
=
`
cygpath
--path
--windows
"
$JAVA_HOME
"
`
[
-n
"
$CLASSPATH
"
]
&&
CLASSPATH
=
`
cygpath
--path
--windows
"
$CLASSPATH
"
`
[
-n
"
$MAVEN_PROJECTBASEDIR
"
]
&&
MAVEN_PROJECTBASEDIR
=
`
cygpath
--path
--windows
"
$MAVEN_PROJECTBASEDIR
"
`
fi
# Provide a "standardized" way to retrieve the CLI args that will
# work with both Windows and non-Windows executions.
MAVEN_CMD_LINE_ARGS
=
"
$MAVEN_CONFIG
$@
"
export
MAVEN_CMD_LINE_ARGS
WRAPPER_LAUNCHER
=
org.apache.maven.wrapper.MavenWrapperMain
exec
"
$JAVACMD
"
\
$MAVEN_OPTS
\
$MAVEN_DEBUG_OPTS
\
-classpath
"
$MAVEN_PROJECTBASEDIR
/.mvn/wrapper/maven-wrapper.jar"
\
"-Dmaven.home=
${
M2_HOME
}
"
\
"-Dmaven.multiModuleProjectDirectory=
${
MAVEN_PROJECTBASEDIR
}
"
\
${
WRAPPER_LAUNCHER
}
$MAVEN_CONFIG
"
$@
"
This diff is collapsed.
Click to expand it.
mvnw.cmd
0 → 100644
View file @
0cb10640
@REM ----------------------------------------------------------------------------
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM https://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM ----------------------------------------------------------------------------
@REM ----------------------------------------------------------------------------
@REM Maven Start Up Batch script
@REM
@REM Required ENV vars:
@REM JAVA_HOME - location of a JDK home dir
@REM
@REM Optional ENV vars
@REM M2_HOME - location of maven2's installed home dir
@REM MAVEN_BATCH_ECHO - set to 'on' to enable the echoing of the batch commands
@REM MAVEN_BATCH_PAUSE - set to 'on' to wait for a keystroke before ending
@REM MAVEN_OPTS - parameters passed to the Java VM when running Maven
@REM e.g. to debug Maven itself, use
@REM set MAVEN_OPTS=-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=y,address=8000
@REM MAVEN_SKIP_RC - flag to disable loading of mavenrc files
@REM ----------------------------------------------------------------------------
@REM Begin all REM lines with '@' in case MAVEN_BATCH_ECHO is 'on'
@echo off
@REM set title of command window
title %0
@REM enable echoing by setting MAVEN_BATCH_ECHO to 'on'
@if "%MAVEN_BATCH_ECHO%" == "on" echo %MAVEN_BATCH_ECHO%
@REM set %HOME% to equivalent of $HOME
if "%HOME%" == "" (set "HOME=%HOMEDRIVE%%HOMEPATH%")
@REM Execute a user defined script before this one
if not "%MAVEN_SKIP_RC%" == "" goto skipRcPre
@REM check for pre script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_pre.bat" call "%USERPROFILE%\mavenrc_pre.bat" %*
if exist "%USERPROFILE%\mavenrc_pre.cmd" call "%USERPROFILE%\mavenrc_pre.cmd" %*
:skipRcPre
@setlocal
set ERROR_CODE=0
@REM To isolate internal variables from possible post scripts, we use another setlocal
@setlocal
@REM ==== START VALIDATION ====
if not "%JAVA_HOME%" == "" goto OkJHome
echo.
echo Error: JAVA_HOME not found in your environment. >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
:OkJHome
if exist "%JAVA_HOME%\bin\java.exe" goto init
echo.
echo Error: JAVA_HOME is set to an invalid directory. >&2
echo JAVA_HOME = "%JAVA_HOME%" >&2
echo Please set the JAVA_HOME variable in your environment to match the >&2
echo location of your Java installation. >&2
echo.
goto error
@REM ==== END VALIDATION ====
:init
@REM Find the project base dir, i.e. the directory that contains the folder ".mvn".
@REM Fallback to current working directory if not found.
set MAVEN_PROJECTBASEDIR=%MAVEN_BASEDIR%
IF NOT "%MAVEN_PROJECTBASEDIR%"=="" goto endDetectBaseDir
set EXEC_DIR=%CD%
set WDIR=%EXEC_DIR%
:findBaseDir
IF EXIST "%WDIR%"\.mvn goto baseDirFound
cd ..
IF "%WDIR%"=="%CD%" goto baseDirNotFound
set WDIR=%CD%
goto findBaseDir
:baseDirFound
set MAVEN_PROJECTBASEDIR=%WDIR%
cd "%EXEC_DIR%"
goto endDetectBaseDir
:baseDirNotFound
set MAVEN_PROJECTBASEDIR=%EXEC_DIR%
cd "%EXEC_DIR%"
:endDetectBaseDir
IF NOT EXIST "%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config" goto endReadAdditionalConfig
@setlocal EnableExtensions EnableDelayedExpansion
for /F "usebackq delims=" %%a in ("%MAVEN_PROJECTBASEDIR%\.mvn\jvm.config") do set JVM_CONFIG_MAVEN_PROPS=!JVM_CONFIG_MAVEN_PROPS! %%a
@endlocal & set JVM_CONFIG_MAVEN_PROPS=%JVM_CONFIG_MAVEN_PROPS%
:endReadAdditionalConfig
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
set WRAPPER_JAR="%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.jar"
set WRAPPER_LAUNCHER=org.apache.maven.wrapper.MavenWrapperMain
set DOWNLOAD_URL="https://repo.maven.apache.org/maven2/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
FOR /F "usebackq tokens=1,2 delims==" %%A IN ("%MAVEN_PROJECTBASEDIR%\.mvn\wrapper\maven-wrapper.properties") DO (
IF "%%A"=="wrapperUrl" SET DOWNLOAD_URL=%%B
)
@REM Extension to allow automatically downloading the maven-wrapper.jar from Maven-central
@REM This allows using the maven wrapper in projects that prohibit checking in binary data.
if exist %WRAPPER_JAR% (
if "%MVNW_VERBOSE%" == "true" (
echo Found %WRAPPER_JAR%
)
) else (
if not "%MVNW_REPOURL%" == "" (
SET DOWNLOAD_URL="%MVNW_REPOURL%/org/apache/maven/wrapper/maven-wrapper/3.1.0/maven-wrapper-3.1.0.jar"
)
if "%MVNW_VERBOSE%" == "true" (
echo Couldn't find %WRAPPER_JAR%, downloading it ...
echo Downloading from: %DOWNLOAD_URL%
)
powershell -Command "&{"^
"$webclient = new-object System.Net.WebClient;"^
"if (-not ([string]::IsNullOrEmpty('%MVNW_USERNAME%') -and [string]::IsNullOrEmpty('%MVNW_PASSWORD%'))) {"^
"$webclient.Credentials = new-object System.Net.NetworkCredential('%MVNW_USERNAME%', '%MVNW_PASSWORD%');"^
"}"^
"[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; $webclient.DownloadFile('%DOWNLOAD_URL%', '%WRAPPER_JAR%')"^
"}"
if "%MVNW_VERBOSE%" == "true" (
echo Finished downloading %WRAPPER_JAR%
)
)
@REM End of extension
@REM Provide a "standardized" way to retrieve the CLI args that will
@REM work with both Windows and non-Windows executions.
set MAVEN_CMD_LINE_ARGS=%*
%MAVEN_JAVA_EXE% ^
%JVM_CONFIG_MAVEN_PROPS% ^
%MAVEN_OPTS% ^
%MAVEN_DEBUG_OPTS% ^
-classpath %WRAPPER_JAR% ^
"-Dmaven.multiModuleProjectDirectory=%MAVEN_PROJECTBASEDIR%" ^
%WRAPPER_LAUNCHER% %MAVEN_CONFIG% %*
if ERRORLEVEL 1 goto error
goto end
:error
set ERROR_CODE=1
:end
@endlocal & set ERROR_CODE=%ERROR_CODE%
if not "%MAVEN_SKIP_RC%"=="" goto skipRcPost
@REM check for post script, once with legacy .bat ending and once with .cmd ending
if exist "%USERPROFILE%\mavenrc_post.bat" call "%USERPROFILE%\mavenrc_post.bat"
if exist "%USERPROFILE%\mavenrc_post.cmd" call "%USERPROFILE%\mavenrc_post.cmd"
:skipRcPost
@REM pause the script if MAVEN_BATCH_PAUSE is set to 'on'
if "%MAVEN_BATCH_PAUSE%"=="on" pause
if "%MAVEN_TERMINATE_CMD%"=="on" exit %ERROR_CODE%
cmd /C exit /B %ERROR_CODE%
This diff is collapsed.
Click to expand it.
pom.xml
0 → 100644
View file @
0cb10640
<?xml version="1.0" encoding="UTF-8"?>
<project
xmlns=
"http://maven.apache.org/POM/4.0.0"
xmlns:xsi=
"http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation=
"http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"
>
<modelVersion>
4.0.0
</modelVersion>
<parent>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-parent
</artifactId>
<version>
2.7.3
</version>
<relativePath
/>
<!-- lookup parent from repository -->
</parent>
<groupId>
com.nisum
</groupId>
<artifactId>
spring-reactive-mongo-curd
</artifactId>
<version>
0.0.1-SNAPSHOT
</version>
<name>
spring-reactive-mongo-curd
</name>
<description>
Demo project for Spring Boot
</description>
<properties>
<java.version>
8
</java.version>
</properties>
<dependencies>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-data-mongodb-reactive
</artifactId>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-webflux
</artifactId>
</dependency>
<dependency>
<groupId>
org.projectlombok
</groupId>
<artifactId>
lombok
</artifactId>
<optional>
true
</optional>
</dependency>
<dependency>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-starter-test
</artifactId>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
de.flapdoodle.embed
</groupId>
<artifactId>
de.flapdoodle.embed.mongo
</artifactId>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
io.projectreactor
</groupId>
<artifactId>
reactor-test
</artifactId>
<scope>
test
</scope>
</dependency>
<dependency>
<groupId>
junit
</groupId>
<artifactId>
junit
</artifactId>
<scope>
test
</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>
org.springframework.boot
</groupId>
<artifactId>
spring-boot-maven-plugin
</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>
org.projectlombok
</groupId>
<artifactId>
lombok
</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
This diff is collapsed.
Click to expand it.
src/main/java/com/nisum/reactive/SpringReactiveMongoCurdApplication.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
;
import
org.springframework.boot.SpringApplication
;
import
org.springframework.boot.autoconfigure.SpringBootApplication
;
@SpringBootApplication
public
class
SpringReactiveMongoCurdApplication
{
public
static
void
main
(
String
[]
args
)
{
SpringApplication
.
run
(
SpringReactiveMongoCurdApplication
.
class
,
args
);
}
}
This diff is collapsed.
Click to expand it.
src/main/java/com/nisum/reactive/controller/ProductController.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
.
controller
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.web.bind.annotation.DeleteMapping
;
import
org.springframework.web.bind.annotation.GetMapping
;
import
org.springframework.web.bind.annotation.PathVariable
;
import
org.springframework.web.bind.annotation.PostMapping
;
import
org.springframework.web.bind.annotation.PutMapping
;
import
org.springframework.web.bind.annotation.RequestBody
;
import
org.springframework.web.bind.annotation.RequestMapping
;
import
org.springframework.web.bind.annotation.RequestParam
;
import
org.springframework.web.bind.annotation.RestController
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.service.ProductService
;
import
lombok.extern.slf4j.Slf4j
;
import
reactor.core.publisher.Flux
;
import
reactor.core.publisher.Mono
;
@RestController
@RequestMapping
(
"/products"
)
@Slf4j
public
class
ProductController
{
@Autowired
private
ProductService
service
;
@GetMapping
public
Flux
<
ProductDto
>
getProducts
()
{
return
service
.
getProducts
();
}
@GetMapping
(
"/{id}"
)
public
Mono
<
ProductDto
>
getProduct
(
@PathVariable
String
id
)
{
return
service
.
getProduct
(
id
);
}
@GetMapping
(
"/product-range"
)
public
Flux
<
ProductDto
>
getProductBetweenRange
(
@RequestParam
(
"min"
)
double
min
,
@RequestParam
(
"max"
)
double
max
)
{
return
service
.
getProductInRange
(
min
,
max
);
}
@PostMapping
public
Mono
<
ProductDto
>
saveProduct
(
@RequestBody
Mono
<
ProductDto
>
productDtoMono
)
{
System
.
out
.
println
(
"controller method called ..."
);
return
service
.
saveProduct
(
productDtoMono
);
}
@PutMapping
(
"/update/{id}"
)
public
Mono
<
ProductDto
>
updateProduct
(
@RequestBody
Mono
<
ProductDto
>
productDtoMono
,
@PathVariable
String
id
)
{
return
service
.
updateProduct
(
productDtoMono
,
id
);
}
@DeleteMapping
(
"/delete/{id}"
)
public
Mono
<
Void
>
deleteProduct
(
@PathVariable
String
id
)
{
return
service
.
deleteProduct
(
id
);
}
}
This diff is collapsed.
Click to expand it.
src/main/java/com/nisum/reactive/dto/ProductDto.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
.
dto
;
import
lombok.AllArgsConstructor
;
import
lombok.Data
;
import
lombok.NoArgsConstructor
;
@Data
@AllArgsConstructor
@NoArgsConstructor
public
class
ProductDto
{
private
String
id
;
private
String
name
;
private
int
qty
;
private
double
price
;
}
This diff is collapsed.
Click to expand it.
src/main/java/com/nisum/reactive/entity/Product.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
.
entity
;
import
org.springframework.data.annotation.Id
;
import
org.springframework.data.mongodb.core.mapping.Document
;
import
lombok.AllArgsConstructor
;
import
lombok.Data
;
import
lombok.NoArgsConstructor
;
@Data
@AllArgsConstructor
@NoArgsConstructor
@Document
(
collection
=
"products"
)
public
class
Product
{
@Id
private
String
id
;
private
String
name
;
private
int
qty
;
private
double
price
;
}
This diff is collapsed.
Click to expand it.
src/main/java/com/nisum/reactive/repository/ProductRepository.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
.
repository
;
import
org.springframework.data.domain.Range
;
import
org.springframework.data.mongodb.repository.ReactiveMongoRepository
;
import
org.springframework.stereotype.Repository
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.entity.Product
;
import
reactor.core.publisher.Flux
;
@Repository
public
interface
ProductRepository
extends
ReactiveMongoRepository
<
Product
,
String
>
{
Flux
<
ProductDto
>
findByPriceBetween
(
Range
<
Double
>
priceRange
);
}
This diff is collapsed.
Click to expand it.
src/main/java/com/nisum/reactive/service/ProductService.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
.
service
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.data.domain.Range
;
import
org.springframework.stereotype.Service
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.repository.ProductRepository
;
import
com.nisum.reactive.util.AppUtils
;
import
lombok.extern.slf4j.Slf4j
;
import
reactor.core.publisher.Flux
;
import
reactor.core.publisher.Mono
;
@Service
@Slf4j
public
class
ProductService
{
@Autowired
private
ProductRepository
repository
;
public
Flux
<
ProductDto
>
getProducts
()
{
return
repository
.
findAll
().
map
(
AppUtils:
:
entityToDto
);
}
public
Mono
<
ProductDto
>
getProduct
(
String
id
)
{
return
repository
.
findById
(
id
).
map
(
AppUtils:
:
entityToDto
);
}
public
Flux
<
ProductDto
>
getProductInRange
(
double
min
,
double
max
)
{
return
repository
.
findByPriceBetween
(
Range
.
closed
(
min
,
max
));
}
public
Mono
<
ProductDto
>
saveProduct
(
Mono
<
ProductDto
>
productDtoMono
)
{
System
.
out
.
println
(
"service method called ..."
);
return
productDtoMono
.
map
(
AppUtils:
:
dtoToEntity
).
flatMap
(
repository:
:
insert
).
map
(
AppUtils:
:
entityToDto
);
}
public
Mono
<
ProductDto
>
updateProduct
(
Mono
<
ProductDto
>
productDtoMono
,
String
id
)
{
return
repository
.
findById
(
id
)
.
flatMap
(
p
->
productDtoMono
.
map
(
AppUtils:
:
dtoToEntity
).
doOnNext
(
e
->
e
.
setId
(
id
)))
.
flatMap
(
repository:
:
save
).
map
(
AppUtils:
:
entityToDto
);
}
public
Mono
<
Void
>
deleteProduct
(
String
id
)
{
return
repository
.
deleteById
(
id
);
}
}
This diff is collapsed.
Click to expand it.
src/main/java/com/nisum/reactive/util/AppUtils.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
.
util
;
import
org.springframework.beans.BeanUtils
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.entity.Product
;
public
class
AppUtils
{
public
static
ProductDto
entityToDto
(
Product
product
)
{
ProductDto
productDto
=
new
ProductDto
();
BeanUtils
.
copyProperties
(
product
,
productDto
);
return
productDto
;
}
public
static
Product
dtoToEntity
(
ProductDto
productDto
)
{
Product
product
=
new
Product
();
BeanUtils
.
copyProperties
(
productDto
,
product
);
return
product
;
}
}
This diff is collapsed.
Click to expand it.
src/main/resources/application.properties
0 → 100644
View file @
0cb10640
#server.port=9999
#spring.data.mongodb.database=Productsdb
#spring.data.mongodb.host=localhost
#
spring.data.mongodb.port
=
27017
\ No newline at end of file
This diff is collapsed.
Click to expand it.
src/main/resources/application.yml
0 → 100644
View file @
0cb10640
spring
:
data
:
mongodb
:
database
:
Productsdb
host
:
localhost
port
:
27017
server
:
port
:
9999
\ No newline at end of file
This diff is collapsed.
Click to expand it.
src/test/java/com/nisum/reactive/ProductServiceTest.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
;
import
static
org
.
junit
.
Assert
.
assertThat
;
import
static
org
.
junit
.
jupiter
.
api
.
Assertions
.
assertEquals
;
import
static
org
.
mockito
.
ArgumentMatchers
.
any
;
import
org.junit.jupiter.api.BeforeEach
;
import
org.junit.jupiter.api.Test
;
import
org.mockito.BDDMockito
;
import
org.mockito.Mockito
;
import
org.springframework.boot.test.mock.mockito.MockBean
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.entity.Product
;
import
com.nisum.reactive.repository.ProductRepository
;
import
com.nisum.reactive.service.ProductService
;
import
com.nisum.reactive.util.AppUtils
;
import
reactor.core.publisher.Flux
;
import
reactor.core.publisher.Mono
;
import
reactor.test.StepVerifier
;
public
class
ProductServiceTest
{
private
ProductRepository
productRepository
;
@MockBean
private
ProductService
productService
;
@BeforeEach
public
void
setUp
()
{
productRepository
=
Mockito
.
mock
(
ProductRepository
.
class
);
productService
=
Mockito
.
mock
(
ProductService
.
class
);
}
@Test
public
void
getProductsTest
()
{
Flux
<
Product
>
productFlux
=
Flux
.
just
(
new
Product
(
"102"
,
"mobile"
,
1
,
10000
),
new
Product
(
"103"
,
"TV"
,
1
,
50000
));
Flux
<
ProductDto
>
productDtoFlux
=
Flux
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
),
new
ProductDto
(
"103"
,
"TV"
,
1
,
50000
));
// BDDMockito.given(productRepository.findAll()).willReturn(productFlux);
BDDMockito
.
given
(
productService
.
getProducts
()).
willReturn
(
productDtoFlux
);
Flux
<
ProductDto
>
result
=
productService
.
getProducts
();
System
.
out
.
println
(
result
);
StepVerifier
.
create
(
result
)
.
expectSubscription
()
.
expectNextMatches
(
p
->
p
.
getName
().
equals
(
"mobile"
))
.
expectNextMatches
(
p
->
p
.
getName
().
equals
(
"TV"
))
.
verifyComplete
();
}
@Test
public
void
getProductTest
()
{
Mono
<
Product
>
productFlux
=
Mono
.
just
(
new
Product
(
"102"
,
"mobile"
,
1
,
10000
));
Mono
<
ProductDto
>
productDtoFlux
=
Mono
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
));
// BDDMockito.given(productRepository.findAll()).willReturn(productFlux);
BDDMockito
.
given
(
productService
.
getProduct
(
any
())).
willReturn
(
productDtoFlux
);
Mono
<
ProductDto
>
result
=
productService
.
getProduct
(
"102"
);
System
.
out
.
println
(
result
);
StepVerifier
.
create
(
result
)
.
expectSubscription
()
.
expectNextMatches
(
p
->
p
.
getName
().
equals
(
"mobile"
))
.
verifyComplete
();
}
}
This diff is collapsed.
Click to expand it.
src/test/java/com/nisum/reactive/SpringBootApplicationTest.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
;
import
static
org
.
mockito
.
ArgumentMatchers
.
any
;
import
static
org
.
mockito
.
ArgumentMatchers
.
anyDouble
;
import
static
org
.
mockito
.
BDDMockito
.
given
;
import
static
org
.
mockito
.
Mockito
.
when
;
import
org.junit.jupiter.api.Test
;
import
org.mockito.BDDMockito
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest
;
import
org.springframework.boot.test.mock.mockito.MockBean
;
import
org.springframework.test.web.reactive.server.WebTestClient
;
import
com.nisum.reactive.controller.ProductController
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.service.ProductService
;
import
reactor.core.publisher.Flux
;
import
reactor.core.publisher.Mono
;
@WebFluxTest
(
controllers
=
ProductController
.
class
)
public
class
SpringBootApplicationTest
{
@MockBean
private
ProductService
productService
;
@Autowired
private
WebTestClient
webTestClient
;
@Test
public
void
addProductTest
()
{
Mono
<
ProductDto
>
productDtoMono
=
Mono
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
));
when
(
productService
.
saveProduct
(
productDtoMono
)).
thenReturn
(
productDtoMono
);
webTestClient
.
post
().
uri
(
"/products"
).
body
(
Mono
.
just
(
productDtoMono
),
ProductDto
.
class
).
exchange
()
.
expectStatus
().
isOk
();
// 200
}
@Test
public
void
getProductsTest
()
throws
Exception
{
Flux
<
ProductDto
>
productDtoFlux
=
Flux
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
),
new
ProductDto
(
"103"
,
"TV"
,
1
,
50000
));
BDDMockito
.
given
(
productService
.
getProducts
()).
willReturn
(
productDtoFlux
);
/*
* import static org.springframework.test.web.servlet.request.MockMvcRequestBuilders.get;
* import static org.springframework.test.web.servlet.result.MockMvcResultMatchers.status;
* @Autowired private MockMvc mockMvc;
* mockMvc.perform(get("/products")) .andExpect(status().isOk());
*/
webTestClient
.
get
().
uri
(
"/products"
).
exchange
().
expectStatus
().
isOk
();
}
@Test
public
void
getProductTest
(){
Mono
<
ProductDto
>
productDtoMono
=
Mono
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
));
when
(
productService
.
getProduct
(
any
())).
thenReturn
(
productDtoMono
);
webTestClient
.
get
().
uri
(
"/products/102"
)
.
exchange
()
.
expectStatus
().
isOk
();
}
@Test
public
void
getProductsBetweenRange
()
{
Flux
<
ProductDto
>
productDtoFlux
=
Flux
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
),
new
ProductDto
(
"103"
,
"TV"
,
1
,
50000
));
BDDMockito
.
given
(
productService
.
getProductInRange
(
anyDouble
(),
anyDouble
())).
willReturn
(
productDtoFlux
);
webTestClient
.
get
().
uri
(
"/products/product-range?min=1000&max=10000"
)
.
exchange
()
.
expectStatus
().
isOk
();
}
@Test
public
void
updateProductTest
(){
Mono
<
ProductDto
>
productDtoMono
=
Mono
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
));
when
(
productService
.
updateProduct
(
productDtoMono
,
"102"
)).
thenReturn
(
productDtoMono
);
webTestClient
.
put
().
uri
(
"/products/update/102"
)
.
body
(
Mono
.
just
(
productDtoMono
),
ProductDto
.
class
)
.
exchange
()
.
expectStatus
().
isOk
();
//200
}
@Test
public
void
deleteProductTest
(){
given
(
productService
.
deleteProduct
(
any
())).
willReturn
(
Mono
.
empty
());
webTestClient
.
delete
().
uri
(
"/products/delete/102"
)
.
exchange
()
.
expectStatus
().
isOk
();
//200
}
}
This diff is collapsed.
Click to expand it.
src/test/java/com/nisum/reactive/SpringBootReactiveControllerTest.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
;
import
static
org
.
springframework
.
test
.
web
.
servlet
.
request
.
MockMvcRequestBuilders
.
get
;
import
static
org
.
springframework
.
test
.
web
.
servlet
.
result
.
MockMvcResultMatchers
.
status
;
import
org.junit.jupiter.api.Test
;
import
org.mockito.BDDMockito
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest
;
import
org.springframework.boot.test.mock.mockito.MockBean
;
import
org.springframework.test.web.servlet.MockMvc
;
import
com.nisum.reactive.controller.ProductController
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.service.ProductService
;
import
reactor.core.publisher.Flux
;
@WebFluxTest
(
controllers
=
ProductController
.
class
)
// this test class is not working getting error
public
class
SpringBootReactiveControllerTest
{
@MockBean
private
ProductService
productService
;
@Autowired
private
MockMvc
mockMvc
;
@Test
public
void
getProducts
()
throws
Exception
{
Flux
<
ProductDto
>
productDtoFlux
=
Flux
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
),
new
ProductDto
(
"103"
,
"TV"
,
1
,
50000
));
BDDMockito
.
given
(
productService
.
getProducts
()).
willReturn
(
productDtoFlux
);
mockMvc
.
perform
(
get
(
"/products"
)).
andExpect
(
status
().
isOk
());
}
}
This diff is collapsed.
Click to expand it.
src/test/java/com/nisum/reactive/SpringReactiveMongoCurdApplicationTests.java
0 → 100644
View file @
0cb10640
package
com
.
nisum
.
reactive
;
import
static
org
.
mockito
.
ArgumentMatchers
.
any
;
import
static
org
.
mockito
.
BDDMockito
.
given
;
import
static
org
.
mockito
.
Mockito
.
when
;
import
org.junit.jupiter.api.Test
;
import
org.junit.jupiter.api.extension.ExtendWith
;
import
org.springframework.beans.factory.annotation.Autowired
;
import
org.springframework.boot.test.autoconfigure.web.reactive.WebFluxTest
;
import
org.springframework.boot.test.mock.mockito.MockBean
;
import
org.springframework.test.context.junit.jupiter.SpringExtension
;
import
org.springframework.test.web.reactive.server.WebTestClient
;
import
com.nisum.reactive.controller.ProductController
;
import
com.nisum.reactive.dto.ProductDto
;
import
com.nisum.reactive.service.ProductService
;
import
reactor.core.publisher.Flux
;
import
reactor.core.publisher.Mono
;
import
reactor.test.StepVerifier
;
//@RunWith(SpringRunner.class)
@ExtendWith
(
SpringExtension
.
class
)
/*
* @ExtendWith(SpringExtension.class)
* We are using @ExtendWith( SpringExtension.class ) to support testing in Junit 5
* In Junit 4, we need to use @RunWith(SpringRunner.class)
* @ExtendWith(SpringExtension.class) giving good performence compare with @RunWith(SpringRunner.class).
* https://howtodoinjava.com/spring-webflux/webfluxtest-with-webtestclient/
*/
@WebFluxTest
(
controllers
=
ProductController
.
class
)
class
SpringReactiveMongoCurdApplicationTests
{
@Autowired
private
WebTestClient
webTestClient
;
@MockBean
private
ProductService
service
;
@Test
public
void
addProductTest
()
{
Mono
<
ProductDto
>
productDtoMono
=
Mono
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
));
when
(
service
.
saveProduct
(
productDtoMono
)).
thenReturn
(
productDtoMono
);
webTestClient
.
post
().
uri
(
"/products"
).
body
(
Mono
.
just
(
productDtoMono
),
ProductDto
.
class
).
exchange
()
.
expectStatus
().
isOk
();
// 200
}
@Test
public
void
getProductsTest
(){
Flux
<
ProductDto
>
productDtoFlux
=
Flux
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
),
new
ProductDto
(
"103"
,
"TV"
,
1
,
50000
));
when
(
service
.
getProducts
()).
thenReturn
(
productDtoFlux
);
Flux
<
ProductDto
>
responseBody
=
webTestClient
.
get
().
uri
(
"/products"
)
.
exchange
()
.
expectStatus
().
isOk
()
.
returnResult
(
ProductDto
.
class
)
.
getResponseBody
();
StepVerifier
.
create
(
responseBody
)
.
expectSubscription
()
.
expectNext
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
))
.
expectNext
(
new
ProductDto
(
"103"
,
"TV"
,
1
,
50000
))
.
verifyComplete
();
}
@Test
public
void
getProductTest
(){
Mono
<
ProductDto
>
productDtoMono
=
Mono
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
));
when
(
service
.
getProduct
(
any
())).
thenReturn
(
productDtoMono
);
Flux
<
ProductDto
>
responseBody
=
webTestClient
.
get
().
uri
(
"/products/102"
)
.
exchange
()
.
expectStatus
().
isOk
()
.
returnResult
(
ProductDto
.
class
)
.
getResponseBody
();
StepVerifier
.
create
(
responseBody
)
.
expectSubscription
()
.
expectNextMatches
(
p
->
p
.
getName
().
equals
(
"mobile"
))
.
verifyComplete
();
}
@Test
public
void
updateProductTest
(){
Mono
<
ProductDto
>
productDtoMono
=
Mono
.
just
(
new
ProductDto
(
"102"
,
"mobile"
,
1
,
10000
));
when
(
service
.
updateProduct
(
productDtoMono
,
"102"
)).
thenReturn
(
productDtoMono
);
webTestClient
.
put
().
uri
(
"/products/update/102"
)
.
body
(
Mono
.
just
(
productDtoMono
),
ProductDto
.
class
)
.
exchange
()
.
expectStatus
().
isOk
();
//200
}
@Test
public
void
deleteProductTest
(){
given
(
service
.
deleteProduct
(
any
())).
willReturn
(
Mono
.
empty
());
webTestClient
.
delete
().
uri
(
"/products/delete/102"
)
.
exchange
()
.
expectStatus
().
isOk
();
//200
}
}
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment