mirror of
https://github.com/octoleo/plantuml-server.git
synced 2024-12-23 01:08:54 +00:00
[FEATURE] Draft of the Check Syntax service
This commit is contained in:
parent
9401ab4a61
commit
9ca32c8d22
@ -0,0 +1,74 @@
|
|||||||
|
/* ========================================================================
|
||||||
|
* PlantUML : a free UML diagram generator
|
||||||
|
* ========================================================================
|
||||||
|
*
|
||||||
|
* Project Info: http://plantuml.sourceforge.net
|
||||||
|
*
|
||||||
|
* This file is part of PlantUML.
|
||||||
|
*
|
||||||
|
* PlantUML is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* PlantUML distributed in the hope that it will be useful, but
|
||||||
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
||||||
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
||||||
|
* License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public
|
||||||
|
* License along with this library; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301,
|
||||||
|
* USA.
|
||||||
|
*/
|
||||||
|
package net.sourceforge.plantuml.servlet;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
|
||||||
|
import javax.imageio.IIOException;
|
||||||
|
import javax.servlet.ServletException;
|
||||||
|
import javax.servlet.http.HttpServlet;
|
||||||
|
import javax.servlet.http.HttpServletRequest;
|
||||||
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
|
||||||
|
import net.sourceforge.plantuml.FileFormat;
|
||||||
|
|
||||||
|
import net.sourceforge.plantuml.servlet.utility.UmlExtractor;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Check servlet of the webapp.
|
||||||
|
* This servlet checks the syntax of the diagram and send a report in TEXT format.
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("serial")
|
||||||
|
public class CheckSyntaxServlet extends HttpServlet {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void doGet(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException {
|
||||||
|
|
||||||
|
// build the UML source from the compressed request parameter
|
||||||
|
String uml = UmlExtractor.getUmlSource(getSource(request.getRequestURI()));
|
||||||
|
|
||||||
|
// generate the response
|
||||||
|
DiagramResponse dr = new DiagramResponse(response, getOutputFormat());
|
||||||
|
try {
|
||||||
|
dr.sendCheck(uml);
|
||||||
|
} catch (IIOException iioe) {
|
||||||
|
// Browser has closed the connection, do nothing
|
||||||
|
}
|
||||||
|
dr = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getSource(String uri) {
|
||||||
|
String[] result = uri.split("/check/", 2);
|
||||||
|
if (result.length != 2) {
|
||||||
|
return "";
|
||||||
|
} else {
|
||||||
|
return result[1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public FileFormat getOutputFormat() {
|
||||||
|
return FileFormat.UTXT;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -35,6 +35,7 @@ import net.sourceforge.plantuml.FileFormat;
|
|||||||
import net.sourceforge.plantuml.FileFormatOption;
|
import net.sourceforge.plantuml.FileFormatOption;
|
||||||
import net.sourceforge.plantuml.SourceStringReader;
|
import net.sourceforge.plantuml.SourceStringReader;
|
||||||
import net.sourceforge.plantuml.StringUtils;
|
import net.sourceforge.plantuml.StringUtils;
|
||||||
|
import net.sourceforge.plantuml.core.DiagramDescription;
|
||||||
import net.sourceforge.plantuml.servlet.utility.NullOutputStream;
|
import net.sourceforge.plantuml.servlet.utility.NullOutputStream;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -81,6 +82,14 @@ class DiagramResponse {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void sendCheck(String uml) throws IOException {
|
||||||
|
response.setContentType(getContentType());
|
||||||
|
SourceStringReader reader = new SourceStringReader(uml);
|
||||||
|
DiagramDescription desc = reader.generateDiagramDescription(
|
||||||
|
new NullOutputStream(), new FileFormatOption(FileFormat.PNG, false));
|
||||||
|
PrintWriter httpOut = response.getWriter();
|
||||||
|
httpOut.print(desc.getDescription());
|
||||||
|
}
|
||||||
private void addHeaderForCache() {
|
private void addHeaderForCache() {
|
||||||
long today = System.currentTimeMillis();
|
long today = System.currentTimeMillis();
|
||||||
// Add http headers to force the browser to cache the image
|
// Add http headers to force the browser to cache the image
|
||||||
|
@ -38,6 +38,10 @@
|
|||||||
<servlet>
|
<servlet>
|
||||||
<servlet-name>mapservlet</servlet-name>
|
<servlet-name>mapservlet</servlet-name>
|
||||||
<servlet-class>net.sourceforge.plantuml.servlet.MapServlet</servlet-class>
|
<servlet-class>net.sourceforge.plantuml.servlet.MapServlet</servlet-class>
|
||||||
|
</servlet>
|
||||||
|
<servlet>
|
||||||
|
<servlet-name>checkservlet</servlet-name>
|
||||||
|
<servlet-class>net.sourceforge.plantuml.servlet.CheckSyntaxServlet</servlet-class>
|
||||||
</servlet>
|
</servlet>
|
||||||
<!-- Patterns of the servlet -->
|
<!-- Patterns of the servlet -->
|
||||||
<servlet-mapping>
|
<servlet-mapping>
|
||||||
@ -68,6 +72,10 @@
|
|||||||
<servlet-name>asciiservlet</servlet-name>
|
<servlet-name>asciiservlet</servlet-name>
|
||||||
<url-pattern>/txt/*</url-pattern>
|
<url-pattern>/txt/*</url-pattern>
|
||||||
</servlet-mapping>
|
</servlet-mapping>
|
||||||
|
<servlet-mapping>
|
||||||
|
<servlet-name>checkservlet</servlet-name>
|
||||||
|
<url-pattern>/check/*</url-pattern>
|
||||||
|
</servlet-mapping>
|
||||||
<servlet-mapping>
|
<servlet-mapping>
|
||||||
<servlet-name>mapservlet</servlet-name>
|
<servlet-name>mapservlet</servlet-name>
|
||||||
<url-pattern>/map/*</url-pattern>
|
<url-pattern>/map/*</url-pattern>
|
||||||
|
@ -0,0 +1,44 @@
|
|||||||
|
package net.sourceforge.plantuml.servlet;
|
||||||
|
|
||||||
|
import com.meterware.httpunit.GetMethodWebRequest;
|
||||||
|
import com.meterware.httpunit.WebConversation;
|
||||||
|
import com.meterware.httpunit.WebRequest;
|
||||||
|
import com.meterware.httpunit.WebResponse;
|
||||||
|
|
||||||
|
public class TestCheck extends WebappTestCase {
|
||||||
|
/**
|
||||||
|
* Verifies the generation of a syntax check for the following sample:
|
||||||
|
* Bob -> Alice : hello
|
||||||
|
*/
|
||||||
|
public void testCorrectSequenceDiagram() throws Exception {
|
||||||
|
WebConversation conversation = new WebConversation();
|
||||||
|
WebRequest request = new GetMethodWebRequest(getServerUrl()
|
||||||
|
+ "check/" + TestUtils.SEQBOB);
|
||||||
|
WebResponse response = conversation.getResource(request);
|
||||||
|
// Analyze response
|
||||||
|
// Verifies the Content-Type header
|
||||||
|
assertEquals("Response content type is not TEXT PLAIN", "text/plain", response.getContentType());
|
||||||
|
assertEquals("Response character set is not UTF-8", "UTF-8", response.getCharacterSet());
|
||||||
|
// Get the content, check its first characters and verify its size
|
||||||
|
String checkResult = response.getText();
|
||||||
|
assertTrue("Response content is not starting with (2 participants)",
|
||||||
|
checkResult.startsWith("(2 participants)"));
|
||||||
|
int checkLen = checkResult.length();
|
||||||
|
assertTrue(checkLen > 1);
|
||||||
|
assertTrue(checkLen < 100);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check the syntax of an invalid sequence diagram :
|
||||||
|
* Bob -
|
||||||
|
*/
|
||||||
|
public void testWrongDiagramSyntax() throws Exception {
|
||||||
|
WebConversation conversation = new WebConversation();
|
||||||
|
WebRequest request = new GetMethodWebRequest(getServerUrl() + "check/SyfFKj050000");
|
||||||
|
WebResponse response = conversation.getResource(request);
|
||||||
|
// Analyze response
|
||||||
|
String checkResult = response.getText();
|
||||||
|
assertTrue("Response is not an error", checkResult.startsWith("(Error)"));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user