Skip to content

Commit

Permalink
Implementation of Test #6 in Servlet and Gemini; updated Gemini version.
Browse files Browse the repository at this point in the history
  • Loading branch information
Brian Hauer committed Jun 4, 2013
1 parent c9f3896 commit cdffad8
Show file tree
Hide file tree
Showing 8 changed files with 74 additions and 13 deletions.
2 changes: 1 addition & 1 deletion gemini/.classpath
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@
<classpathentry kind="con" path="org.eclipse.jdt.launching.JRE_CONTAINER/org.eclipse.jdt.internal.debug.ui.launcher.StandardVMType/JavaSE-1.7"/>
<classpathentry kind="var" path="Resin4Jee"/>
<classpathentry kind="lib" path="Docroot/WEB-INF/lib/mysql-connector-java-5.1.23-bin.jar"/>
<classpathentry kind="lib" path="Docroot/WEB-INF/lib/gemini-1.3.6.jar"/>
<classpathentry kind="lib" path="Docroot/WEB-INF/lib/guava-14.0.1.jar"/>
<classpathentry kind="lib" path="Docroot/WEB-INF/lib/trove4j-3.0.3.jar"/>
<classpathentry kind="lib" path="Docroot/WEB-INF/lib/gemini-1.3.7.jar"/>
<classpathentry kind="output" path="Docroot/WEB-INF/classes"/>
</classpath>
Binary file not shown.
5 changes: 3 additions & 2 deletions gemini/Docroot/WEB-INF/mustache/fortunes.mustache
Original file line number Diff line number Diff line change
@@ -1,16 +1,17 @@
{{<layout}}
{{$title}}Fortunes{{/title}}
{{$body}}
<table>
<tr>
<th>id</th>
<th>message</th>
</tr>
{{#.}}
{{#req}}
<tr>
<td>{{id}}</td>
<td>{{message}}</td>
</tr>
{{/.}}
{{/req}}
</table>
{{/body}}
{{/layout}}
2 changes: 1 addition & 1 deletion gemini/Docroot/WEB-INF/mustache/layout.mustache
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
<!DOCTYPE html>
<html>
<head>
<title>Fortunes</title>
<title>{{$title}}{{/title}}</title>
</head>
<body>
{{$body}}{{/body}}
Expand Down
38 changes: 29 additions & 9 deletions gemini/Source/hello/home/handler/HelloHandler.java
Original file line number Diff line number Diff line change
Expand Up @@ -11,11 +11,10 @@
import com.techempower.gemini.path.annotation.*;

/**
* Responds to the framework benchmarking requests for "hello, world" and
* simple database queries.
* Handles the various framework benchmark request types.
*/
public class HelloHandler
extends BasicPathHandler<Context>
extends MethodPathHandler<Context>
{

private static final int DB_ROWS = 10000;
Expand All @@ -34,21 +33,32 @@ public HelloHandler(GeminiApplication app)
/**
* Return "hello world" as a JSON-encoded message.
*/
@PathSegment("json")
@PathDefault
public boolean helloworld()
{
return message("Hello, World!");
}

/**
* Return a list of World objects as JSON, selected randomly from the World
* table. For consistency, we have assumed the table has 10,000 rows.
* Return a single World objects as JSON, selected randomly from the World
* table. Assume the table has 10,000 rows.
*/
@PathSegment
public boolean db()
{
return json(store.get(World.class, ThreadLocalRandom.current().nextInt(DB_ROWS)));
}

/**
* Return a list of World objects as JSON, selected randomly from the World
* table. Assume the table has 10,000 rows.
*/
@PathSegment("query")
public boolean multipleQueries()
{
final Random random = ThreadLocalRandom.current();
final int queries = context().getInt("queries", 1, 1, 500);
final int queries = query().getInt("queries", 1, 1, 500);
final World[] worlds = new World[queries];

for (int i = 0; i < queries; i++)
Expand All @@ -75,14 +85,15 @@ public boolean fortunes()

/**
* Return a list of World objects as JSON, selected randomly from the World
* table. For each row that is retrieved, that row will have it's randomNumber
* field updated and persisted. For consistency, we have assumed the table has 10,000 rows.
* table. For each row that is retrieved, that row will have its
* randomNumber field updated and then the row will be persisted. We
* assume the table has 10,000 rows.
*/
@PathSegment
public boolean update()
{
final Random random = ThreadLocalRandom.current();
final int queries = context().getInt("queries", 1, 1, 500);
final int queries = query().getInt("queries", 1, 1, 500);
final World[] worlds = new World[queries];

for (int i = 0; i < queries; i++)
Expand All @@ -95,5 +106,14 @@ public boolean update()

return json(worlds);
}

/**
* Responds with a plaintext "Hello, World!"
*/
@PathSegment
public boolean plaintext()
{
return text("Hello, World!");
}

}
1 change: 1 addition & 0 deletions servlet/src/main/java/hello/Common.java
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ public class Common
// Constants for setting the content type.
protected static final String HEADER_CONTENT_TYPE = "Content-Type";
protected static final String CONTENT_TYPE_JSON = "application/json";
protected static final String CONTENT_TYPE_TEXT = "text/plain";
protected static final String CONTENT_TYPE_HTML = "text/html";

// Jackson encoder, reused for each response.
Expand Down
33 changes: 33 additions & 0 deletions servlet/src/main/java/hello/PlaintextServlet.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
package hello;

import java.io.*;

import javax.servlet.*;
import javax.servlet.http.*;

/**
* Plaintext rendering Test
*/
@SuppressWarnings("serial")
public class PlaintextServlet extends HttpServlet
{

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse res)
throws ServletException, IOException
{
// Set content type to text/plain.
res.setHeader(Common.HEADER_CONTENT_TYPE, Common.CONTENT_TYPE_TEXT);

// Write plaintext "Hello, World!" to the response.
try
{
res.getWriter().write("Hello, World!");
}
catch (IOException ioe)
{
// do nothing
}
}

}
6 changes: 6 additions & 0 deletions servlet/src/main/webapp/WEB-INF/web.xml
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,12 @@
<load-on-startup/>
</servlet>
<servlet-mapping url-regexp='^/json$' servlet-name='json'/>
<servlet>
<servlet-name>plaintext</servlet-name>
<servlet-class>hello.PlaintextServlet</servlet-class>
<load-on-startup/>
</servlet>
<servlet-mapping url-regexp='^/plaintext$' servlet-name='plaintext'/>
<servlet>
<servlet-name>db</servlet-name>
<servlet-class>hello.DbPoolServlet</servlet-class>
Expand Down

0 comments on commit cdffad8

Please sign in to comment.