git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@885349 13f79535-47bb-0310-9956-ffa450edef68
268 lines
8.7 KiB
C++
268 lines
8.7 KiB
C++
/*
|
|
* 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
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
/* $Rev$ $Date$ */
|
|
|
|
/**
|
|
* Test HTTP client functions.
|
|
*/
|
|
|
|
#include <assert.h>
|
|
#include <sys/time.h>
|
|
#include <time.h>
|
|
#include <iostream>
|
|
#include <sstream>
|
|
#include <string>
|
|
#include "slist.hpp"
|
|
#include "../http/curl.hpp"
|
|
|
|
namespace tuscany {
|
|
namespace server {
|
|
|
|
const bool contains(const std::string& str, const std::string& pattern) {
|
|
return str.find(pattern) != str.npos;
|
|
}
|
|
|
|
const double duration(struct timeval start, struct timeval end, int count) {
|
|
long t = (end.tv_sec * 1000 + end.tv_usec / 1000) - (start.tv_sec * 1000 + start.tv_usec / 1000);
|
|
return (double)t / (double)count;
|
|
}
|
|
|
|
std::ostringstream* curlWriter(const std::string& s, std::ostringstream* os) {
|
|
(*os) << s;
|
|
return os;
|
|
}
|
|
|
|
const bool testGet() {
|
|
http::CURLSession ch;
|
|
{
|
|
std::ostringstream os;
|
|
const failable<list<std::ostringstream*>, std::string> r = http::get<std::ostringstream*>(curlWriter, &os, "http://localhost:8090", ch);
|
|
assert(hasContent(r));
|
|
assert(contains(os.str(), "HTTP/1.1 200 OK"));
|
|
assert(contains(os.str(), "It works"));
|
|
}
|
|
{
|
|
const failable<value, std::string> r = http::get("http://localhost:8090", ch);
|
|
assert(hasContent(r));
|
|
assert(contains(content(r), "It works"));
|
|
}
|
|
return true;
|
|
}
|
|
|
|
const bool testGetLoop(const int count, http::CURLSession& ch) {
|
|
if (count == 0)
|
|
return true;
|
|
const failable<value, std::string> r = get("http://localhost:8090", ch);
|
|
assert(hasContent(r));
|
|
assert(contains(content(r), "It works"));
|
|
return testGetLoop(count - 1, ch);
|
|
}
|
|
|
|
const bool testGetPerf() {
|
|
const int count = 50;
|
|
http::CURLSession ch;
|
|
struct timeval start;
|
|
struct timeval end;
|
|
{
|
|
testGetLoop(5, ch);
|
|
gettimeofday(&start, NULL);
|
|
testGetLoop(count, ch);
|
|
gettimeofday(&end, NULL);
|
|
std::cout << "Static GET test " << duration(start, end, count) << " ms" << std::endl;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
const bool testEval() {
|
|
http::CURLSession ch;
|
|
const value val = content(http::evalExpr(mklist<value>(std::string("echo"), std::string("Hello")), "http://localhost:8090/test", ch));
|
|
assert(val == std::string("Hello"));
|
|
return true;
|
|
}
|
|
|
|
const bool testEvalLoop(const int count, http::CURLSession& ch) {
|
|
if (count == 0)
|
|
return true;
|
|
const value val = content(http::evalExpr(mklist<value>(std::string("echo"), std::string("Hello")), "http://localhost:8090/test", ch));
|
|
assert(val == std::string("Hello"));
|
|
return testEvalLoop(count - 1, ch);
|
|
}
|
|
|
|
const value blob(std::string(3000, 'A'));
|
|
const list<value> blobs = mklist(blob, blob, blob, blob, blob);
|
|
|
|
const bool testBlobEvalLoop(const int count, http::CURLSession& ch) {
|
|
if (count == 0)
|
|
return true;
|
|
const value val = content(http::evalExpr(mklist<value>(std::string("echo"), blobs), "http://localhost:8090/test", ch));
|
|
assert(val == blobs);
|
|
return testBlobEvalLoop(count - 1, ch);
|
|
}
|
|
|
|
const bool testEvalPerf() {
|
|
const int count = 50;
|
|
http::CURLSession ch;
|
|
struct timeval start;
|
|
struct timeval end;
|
|
{
|
|
testEvalLoop(5, ch);
|
|
gettimeofday(&start, NULL);
|
|
testEvalLoop(count, ch);
|
|
gettimeofday(&end, NULL);
|
|
std::cout << "JSON-RPC eval echo test " << duration(start, end, count) << " ms" << std::endl;
|
|
}
|
|
{
|
|
testBlobEvalLoop(5, ch);
|
|
gettimeofday(&start, NULL);
|
|
testBlobEvalLoop(count, ch);
|
|
gettimeofday(&end, NULL);
|
|
std::cout << "JSON-RPC eval blob test " << duration(start, end, count) << " ms" << std::endl;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
const bool testFeed() {
|
|
return true;
|
|
}
|
|
|
|
bool testPost() {
|
|
const list<value> i = list<value>()
|
|
<< (list<value>() << "name" << std::string("Apple"))
|
|
<< (list<value>() << "price" << std::string("$2.99"));
|
|
const list<value> a = mklist<value>(std::string("item"), std::string("cart-53d67a61-aa5e-4e5e-8401-39edeba8b83b"), i);
|
|
http::CURLSession ch;
|
|
const failable<value, std::string> id = http::post(a, "http://localhost:8090/test", ch);
|
|
assert(hasContent(id));
|
|
return true;
|
|
}
|
|
|
|
const bool testPostLoop(const int count, const value& val, http::CURLSession& ch) {
|
|
if (count == 0)
|
|
return true;
|
|
const failable<value, std::string> id = http::post(val, "http://localhost:8090/test", ch);
|
|
assert(hasContent(id));
|
|
return testPostLoop(count - 1, val, ch);
|
|
}
|
|
|
|
const bool testPostPerf() {
|
|
const int count = 50;
|
|
http::CURLSession ch;
|
|
struct timeval start;
|
|
struct timeval end;
|
|
{
|
|
const list<value> i = list<value>()
|
|
<< (list<value>() << "name" << std::string("Apple"))
|
|
<< (list<value>() << "price" << std::string("$2.99"));
|
|
const list<value> val = mklist<value>(std::string("item"), std::string("cart-53d67a61-aa5e-4e5e-8401-39edeba8b83b"), i);
|
|
testPostLoop(5, val, ch);
|
|
gettimeofday(&start, NULL);
|
|
testPostLoop(count, val, ch);
|
|
gettimeofday(&end, NULL);
|
|
std::cout << "ATOMPub POST small test " << duration(start, end, count) << " ms" << std::endl;
|
|
}
|
|
{
|
|
const list<value> i = list<value>()
|
|
<< (list<value>() << "name" << std::string("Apple"))
|
|
<< (list<value>() << "blob1" << blob)
|
|
<< (list<value>() << "blob2" << blob)
|
|
<< (list<value>() << "blob3" << blob)
|
|
<< (list<value>() << "blob4" << blob)
|
|
<< (list<value>() << "blob5" << blob)
|
|
<< (list<value>() << "price" << std::string("$2.99"));
|
|
const list<value> val = mklist<value>(std::string("item"), std::string("cart-53d67a61-aa5e-4e5e-8401-39edeba8b83b"), i);
|
|
testPostLoop(5, val, ch);
|
|
gettimeofday(&start, NULL);
|
|
testPostLoop(count, val, ch);
|
|
gettimeofday(&end, NULL);
|
|
std::cout << "ATOMPub POST blob test " << duration(start, end, count) << " ms" << std::endl;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
const bool testPut() {
|
|
const list<value> i = list<value>()
|
|
<< (list<value>() << "name" << std::string("Apple"))
|
|
<< (list<value>() << "price" << std::string("$2.99"));
|
|
const list<value> a = mklist<value>(std::string("item"), std::string("cart-53d67a61-aa5e-4e5e-8401-39edeba8b83b"), i);
|
|
http::CURLSession ch;
|
|
value rc = content(http::put(a, "http://localhost:8090/test/111", ch));
|
|
assert(rc == value(true));
|
|
return true;
|
|
}
|
|
|
|
const bool testDel() {
|
|
http::CURLSession ch;
|
|
value rc = content(http::del("http://localhost:8090/test/123456789", ch));
|
|
assert(rc == value(true));
|
|
return true;
|
|
}
|
|
|
|
const bool testEvalCpp() {
|
|
http::CURLSession ch;
|
|
const value val = content(http::evalExpr(mklist<value>(std::string("hello"), std::string("world")), "http://localhost:8090/cpp", ch));
|
|
assert(val == std::string("hello world"));
|
|
return true;
|
|
}
|
|
|
|
const bool testEvalCppLoop(const int count, http::CURLSession& ch) {
|
|
if (count == 0)
|
|
return true;
|
|
const value val = content(http::evalExpr(mklist<value>(std::string("hello"), std::string("world")), "http://localhost:8090/cpp", ch));
|
|
assert(val == std::string("hello world"));
|
|
return testEvalCppLoop(count - 1, ch);
|
|
}
|
|
|
|
const bool testEvalCppPerf() {
|
|
const int count = 50;
|
|
http::CURLSession ch;
|
|
struct timeval start;
|
|
struct timeval end;
|
|
{
|
|
testEvalCppLoop(5, ch);
|
|
gettimeofday(&start, NULL);
|
|
testEvalCppLoop(count, ch);
|
|
gettimeofday(&end, NULL);
|
|
std::cout << "JSON-RPC C++ eval test " << duration(start, end, count) << " ms" << std::endl;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
int main() {
|
|
std::cout << "Testing..." << std::endl;
|
|
|
|
tuscany::server::testGet();
|
|
tuscany::server::testGetPerf();
|
|
tuscany::server::testPost();
|
|
tuscany::server::testPostPerf();
|
|
tuscany::server::testEval();
|
|
tuscany::server::testEvalPerf();
|
|
tuscany::server::testFeed();
|
|
tuscany::server::testPut();
|
|
tuscany::server::testDel();
|
|
tuscany::server::testEvalCpp();
|
|
tuscany::server::testEvalCppPerf();
|
|
|
|
std::cout << "OK" << std::endl;
|
|
|
|
return 0;
|
|
}
|