1

取得している Tornado コード ベースのテストを作成しようとしています。プロジェクトは正常に実行されますが、作成した最初のテストで接続拒否エラーが発生します。

コードは次のとおりです。

import unittest, os, os.path, sys, urllib
import tornado.options
from tornado.options import options
from tornado.testing import AsyncHTTPTestCase


APP_ROOT = os.path.abspath(os.path.join(os.path.dirname(__file__), '..'))
sys.path.append(os.path.join(APP_ROOT, '..'))
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), os.path.pardir)))

from main import Application

app = Application()

def clear_db(app=None):
    os.system("mysql -u user --password=pw --database=testdb < %s" % (os.path.join(APP_ROOT, 'db', 'schema.sql')))

class TestHandlerBase(AsyncHTTPTestCase):
    def setUp(self):
        clear_db()
        super(TestHandlerBase, self).setUp()

    def get_app(self):
        return app

    def get_http_port(self):
        return 5000

class TestRootHandler(TestHandlerBase):
    def test_redirect(self):
        response = self.fetch(
            '/',
            method='GET',
            follow_redirects=False)
        print response
        self.assertTrue(response.headers['Location'].endswith('/login'))

これは私が得る応答です:

HTTPResponse(_body=None, buffer=None, code=599, 
  effective_url='http://localhost:5000/',
  error=HTTPError('HTTP 599: [Errno 61] Connection refused',), 
  headers={}, reason='Unknown', 
  request=<tornado.httpclient.HTTPRequest object at 0x10c363510>, 
  request_time=0.01304006576538086, time_info={})

エラーの原因について何か考えはありますか? テストのためにすべてを実行するために欠けているステップはありますか? ありがとう!!!

4

2 に答える 2

4

オーバーライドしないでくださいget_http_port。テストごとに新しいポートを持つ新しい HTTP サーバーがセットアップされるため、設定にあるものであっても毎回 5000 になることはありません。

于 2013-08-10T19:51:13.323 に答える