| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 | #!/usr/bin/env pythonimport sysimport jsonfrom random import randintimport momokoimport motorimport tornado.ioloopimport tornado.webfrom tornado import genimport tornado.optionsfrom tornado.options import optionsimport tornado.httpserverPY3 = Falseif sys.version_info[0] == 3:    PY3 = True    xrange = rangetornado.options.define('port', default=8888, type=int, help="Server port")tornado.options.define('mongo', default='localhost', type=str, help="MongoDB host")tornado.options.define('postgres', default=None, type=str, help="PostgreSQL host")class BaseHandler(tornado.web.RequestHandler):    def compute_etag(self):        return Noneclass JsonSerializeTestHandler(BaseHandler):    def get(self):        obj = {"message": "Hello, World!", }        self.write(obj)class PlaintextHandler(BaseHandler):    def get(self):        self.set_header('Content-Type', 'text/plain')        self.write(b"Hello, World!")class DBTestHandler(BaseHandler):    @gen.coroutine    def get(self):        world = yield db.World.find_one(randint(1, 10000))        # Get first postion on arguments, and so first postion in mongo return        world['id'] = int(world.pop('_id'))        world['randomNumber'] = int(world['randomNumber'])        response = json.dumps(world)        self.set_header("Content-Type", "application/json; charset=UTF-8")        self.write(response)class QueryTestHandler(BaseHandler):    @gen.coroutine    def get(self):        try:            queries = int(self.get_argument("queries"))        except Exception:            queries = 1        else:            if queries < 1:                queries = 1            elif queries > 500:                queries = 500        worlds = yield [db.World.find_one(randint(1, 10000))                        for _ in xrange(queries)]        for world in worlds:            # Get first postion on arguments, and so first postion in mongo return            world['id'] = int(world.pop('_id'))            world['randomNumber'] = int(world['randomNumber'])        response = json.dumps(worlds)        self.set_header("Content-Type", "application/json; charset=UTF-8")        self.write(response)class QueryPostgresRawTestHandler(BaseHandler):    @gen.coroutine    def get(self):        sql = "SELECT id, randomNumber FROM World WHERE id=%s"        random_id = randint(1, 10000)        cursor = yield self.application.db.execute(sql, (random_id,))        row = cursor.fetchone()        response = json.dumps({"id": row[0], "randomNumber": row[1]})        self.set_header("Content-Type", "application/json; charset=UTF-8")        self.write(response)class MultipleQueriesPostgresRawTestHandler(BaseHandler):    @gen.coroutine    def get(self):        queries = self.get_argument("queries", "1")        try:            queries = int(queries.strip())        except ValueError:            queries = 1        queries = min(max(1, queries), 500)        sql = "SELECT id, randomNumber FROM World WHERE id=%s"        cursors = yield [self.application.db.execute(sql, (randint(1, 10000),)) for _ in xrange(int(queries))]        rows = [cursor.fetchone() for cursor in cursors]         worlds = [{"id": row[0], "randomNumber":row[1]} for row in rows]        response = json.dumps(worlds)        self.set_header("Content-Type", "application/json; charset=UTF-8")        self.write(response)application = tornado.web.Application([    (r"/json", JsonSerializeTestHandler),    (r"/plaintext", PlaintextHandler),    (r"/db", DBTestHandler),    (r"/queries", QueryTestHandler),    (r"/dbraw", QueryPostgresRawTestHandler),    (r"/queriesraw", MultipleQueriesPostgresRawTestHandler)])if __name__ == "__main__":    tornado.options.parse_command_line()    server = tornado.httpserver.HTTPServer(application)    server.bind(options.port)    server.start(0)    ioloop = tornado.ioloop.IOLoop.instance()    if options.postgres:        dsn = "user=benchmarkdbuser password=benchmarkdbpass dbname=hello_world host=%s" % options.postgres        application.db = momoko.Pool(dsn, size=1, max_size=100)        ioloop.run_sync(application.db.connect)    else:        db = motor.MotorClient(options.mongo).hello_world    ioloop.start()
 |