org.rapidoid.benchmark.highlevel.FortunesMultiHandler Maven / Gradle / Ivy
The newest version!
package org.rapidoid.benchmark.highlevel;
/*
* #%L
* rapidoid-benchmark
* %%
* Copyright (C) 2014 - 2017 Nikolche Mihajlovski and contributors
* %%
* Licensed 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
*
* http://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.
* #L%
*/
import org.rapidoid.benchmark.common.Fortune;
import org.rapidoid.http.Req;
import org.rapidoid.http.ReqRespHandler;
import org.rapidoid.http.Resp;
import org.rapidoid.jdbc.JdbcClient;
import org.rapidoid.lambda.Mapper;
import org.rapidoid.render.Template;
import org.rapidoid.render.Templates;
import org.rapidoid.u.U;
import org.rapidoid.util.Wait;
import java.sql.ResultSet;
import java.util.Collections;
import java.util.List;
import java.util.concurrent.CountDownLatch;
public class FortunesMultiHandler implements ReqRespHandler {
private static final String SQL = "SELECT id, message FROM fortune";
private static final Mapper resultMapper = rs -> new Fortune(rs.getInt(1), rs.getString(2));
private final Template template = Templates.load("fortunes.html");
private final JdbcClient jdbc;
public FortunesMultiHandler(JdbcClient jdbc) {
this.jdbc = jdbc;
}
@Override
public Object execute(Req req, Resp resp) throws Exception {
int count = U.num(req.param("n", "1000"));
CountDownLatch latch = new CountDownLatch(count);
for (int i = 0; i < count; i++) {
jdbc.execute(resultMapper, (List fortunes, Throwable err) -> {
if (err == null) {
fortunes.add(new Fortune(0, "Additional fortune added at request time."));
Collections.sort(fortunes);
template.renderToBytes(fortunes);
}
}, SQL);
}
Wait.on(latch);
return "OK".getBytes();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy