Refactort server and client

This commit is contained in:
Dominik Adam Przybysz 2014-12-13 18:56:07 +01:00
parent f72e510fea
commit fda5b6ca5c
13 changed files with 188 additions and 96 deletions

View file

@ -1,32 +1,34 @@
package pl.touk.mockserver.server
import com.sun.net.httpserver.HttpExchange
import groovy.transform.PackageScope
import groovy.util.slurpersupport.GPathResult
import java.util.concurrent.CopyOnWriteArrayList
import java.util.concurrent.CopyOnWriteArraySet
@PackageScope
class HttpMockServer {
private final HttpServerWraper httpServerWraper
private final List<HttpServerWraper> childServers = new CopyOnWriteArrayList<>()
private final Set<String> mockNames = new CopyOnWriteArraySet<>()
HttpMockServer(int port = 9999){
httpServerWraper= new HttpServerWraper(port)
HttpMockServer(int port = 9999) {
httpServerWraper = new HttpServerWraper(port)
httpServerWraper.createContext('/serverControl', {
HttpExchange ex ->
try{
try {
GPathResult request = new XmlSlurper().parse(ex.requestBody)
if(ex.requestMethod== 'POST' && request.name() == 'addMock'){
if (ex.requestMethod == 'POST' && request.name() == 'addMock') {
addMock(request, ex)
}else if(ex.requestMethod == 'POST' && request.name() == 'removeMock'){
} else if (ex.requestMethod == 'POST' && request.name() == 'removeMock') {
removeMock(request, ex)
}
//TODO add get mock report
//TODO add list mock
}catch(Exception e){
} catch (Exception e) {
createErrorResponse(ex, e)
}
})
@ -37,53 +39,45 @@ class HttpMockServer {
if (name in mockNames) {
throw new RuntimeException('mock already registered')
}
println "Adding $name"
String mockPath = request.path
int mockPort = Integer.valueOf(request.port as String)
Mock mock = new Mock(name, mockPath, mockPort)
String predicate = request.predicate
if(predicate){
mock.predicate = Eval.me(predicate) as Closure
}
String okResponse = request.response
if(okResponse){
mock.responseOk = Eval.me(okResponse) as Closure
}
String soap = request.soap
if(soap){
mock.soap = Boolean.valueOf(soap)
}
String statusCode = request.statusCode
if(statusCode){
mock.statusCode = Integer.valueOf(statusCode)
}
String method = request.method
if(method){
mock.method = method
}
String responseHeaders = request.responseHeaders
if(responseHeaders){
mock.responseHeaders = Eval.me(responseHeaders) as Closure
}
HttpServerWraper child = childServers.find { it.port == mockPort }
if (!child) {
child = new HttpServerWraper(mockPort)
childServers << child
}
child.addMock(mockPath, mock)
Mock mock = mockFromRequest(request)
HttpServerWraper child = getOrCreateChildServer(mock.port)
child.addMock(mock)
mockNames << name
ex.sendResponseHeaders(200, 0)
ex.responseBody << '<mockAdded/>'
ex.responseBody.close()
}
private static Mock mockFromRequest(GPathResult request) {
String name = request.name
String mockPath = request.path
int mockPort = Integer.valueOf(request.port as String)
Mock mock = new Mock(name, mockPath, mockPort)
mock.predicate = request.predicate
mock.response = request.response
mock.soap = request.soap
mock.statusCode = request.statusCode
mock.method = request.method
mock.responseHeaders = request.responseHeaders
return mock
}
private HttpServerWraper getOrCreateChildServer(int mockPort) {
HttpServerWraper child = childServers.find { it.port == mockPort }
if (!child) {
child = new HttpServerWraper(mockPort)
childServers << child
}
return child
}
private void removeMock(GPathResult request, HttpExchange ex) {
String name = request.name
if (! (name in mockNames)) {
if (!(name in mockNames)) {
throw new RuntimeException('mock not registered')
}
println "Removing $name"
int used = childServers.inject(0) { int res, HttpServerWraper server-> server.removeMock(name) + res}
int used = childServers.inject(0) { int res, HttpServerWraper server -> server.removeMock(name) + res }
mockNames.remove(name)
ex.sendResponseHeaders(200, 0)
ex.responseBody << "<mockRemoved>$used</mockRemoved>"
@ -96,8 +90,8 @@ class HttpMockServer {
ex.responseBody.close()
}
void stop(){
childServers.each {it.stop()}
void stop() {
childServers.each { it.stop() }
httpServerWraper.stop()
}
}