2017-07-23 120 views
6

Ayarlama testlerini, testtools ve nose2 kullanarak, @classmethod numaralı telefonu aramayı denediğimde, test paketi tamamlanmıyor. Ancak testin gerçekten geçtiğini ve fonksiyonun sonuna ulaştığını kontrol ettim, test paketi çalışmayı bitirmiyor. Testleri decode_auth_token kullanarak kaldırırsam, iyi çalışır. Sınıf yöntemlerini daraltmayı başardım çünkü diğer sınıf yöntemlerini de test ettim ve aynı soruna neden oluyorlarPython Nose2 Sınıf Yöntemi Çağrıldığında Sonlanmayan Testler

Bunun neden olabileceği hakkında bir fikri olan var mı? Aşağıda Bu işlev yapar

@classmethod 
    def is_username_taken(cls, username): 
    return db.session.query(db.exists().where(User.username==username)).scalar() 

    @classmethod 
    def is_email_taken(cls, email): 
    return db.session.query(db.exists().where(User.email==email)).scalar() 

aradığında neden Modeli

@classmethod 
    def decode_auth_token(cls, auth_token): 
    try: 
     payload = jwt.decode(auth_token, config.SECRET_KEY, algorithms=['HS256']) 
     # check the hash of what we expect the token to be and token we got to be the same 
     if bcrypt.check_password_hash(User.by_id(payload['sub']).api_token_hash, auth_token): 
     return payload['sub'] 
     else: 
     return 'Token does not match Api Token.' 
    except jwt.ExpiredSignatureError: 
     return 'Signature expired. Please log in again.' 
    except jwt.InvalidTokenError: 
     return 'Invalid Token. Please log in again.' 

benim Kullanıcı sorunu da aşağıdaki iki işlevi kodumu

Kod çok fazla göndermeden kod alakalı parçalarıdır

@classmethod 
def by_username(cls, username): 
    return User.query.filter(User.username == username).first() 

Burada sorun neden olmaz

import unittest 
import sys 

from . import AppTestCase, API_ROOT 
from app.extensions import db, bcrypt 
from app.models import User, UserSchema, Location, Company 


class TestUserModel(AppTestCase): 
    def test_encode_auth_token(self): 
    user = User.by_username('jdoe') 
    auth_token = user.encode_auth_token(user.id) 
    self.assertTrue(isinstance(auth_token, bytes)) 

    def test_decode_auth_token(self): 
    user = User.by_username('jdoe') 
    auth_token = user.encode_auth_token(user.id) 
    self.assertTrue(isinstance(auth_token, bytes)) 
    self.assertEqual(User.decode_auth_token(auth_token), user.id) 
    print('DONE') 

ilk test çalışıyor test eder ikinci sınama baskıları dışarı Done ve düzgün doğru kullanıcı kimliği dönen auth_token deşifre ama test paketi bitirmek için neden olmaz. Sadece baskı bittikten sonra çalışmaya devam ediyor. Burada

Ve

Ben Koşu ve

running test 
Searching for nose2 
Best match: nose2 0.6.5 
Processing nose2-0.6.5-py3.6.egg 

Using XXX/.eggs/nose2-0.6.5-py3.6.egg 
running egg_info 
writing doomfist.egg-info/PKG-INFO 
writing dependency_links to XXX.egg-info/dependency_links.txt 
writing requirements to XXX.egg-info/requires.txt 
writing top-level names to XXX.egg-info/top_level.txt 
reading manifest file 'XXX.egg-info/SOURCES.txt' 
writing manifest file 'XXX.egg-info/SOURCES.txt' 
running build_ext 
/Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/python_dateutil-2.6.0-py3.6.egg/dateutil/parser.py:50: DeprecationWarning: invalid escape sequence \. 
/Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/python_dateutil-2.6.0-py3.6.egg/dateutil/parser.py:50: DeprecationWarning: invalid escape sequence \. 
/Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/python_dateutil-2.6.0-py3.6.egg/dateutil/tz/win.py:197: DeprecationWarning: invalid escape sequence \{ 
/Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/python_dateutil-2.6.0-py3.6.egg/dateutil/tz/win.py:247: DeprecationWarning: invalid escape sequence \{ 
/Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/python_dateutil-2.6.0-py3.6.egg/dateutil/tz/win.py:197: DeprecationWarning: invalid escape sequence \{ 
/Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/python_dateutil-2.6.0-py3.6.egg/dateutil/tz/win.py:247: DeprecationWarning: invalid escape sequence \{ 
NOT running in debug mode 
DONE 
^]^\[1] 35752 quit  python setup.py test 

EDIT Durdurma Değil zaman python setup.py test

import os 
from setuptools import setup, find_packages, Command 

# Thanks http://stackoverflow.com/questions/3779915/why-does-python-setup-py-sdist-create-unwanted-project-egg-info-in-project-r 
class CleanCommand(Command): 
    """Custom clean command to tidy up the project root.""" 
    user_options = [] 
    def initialize_options(self): 
    pass 
    def finalize_options(self): 
    pass 
    def run(self): 
    os.system('rm -vrf ./build ./dist ./*.pyc ./*.tgz ./*.egg-info') 

with open('requirements.txt') as f: 
    requirements = f.read().splitlines() 

setup(
    name="XXX", 
    description="XXX", 
    version=1.0, 
    packages=find_packages(), 
    install_requires=requirements, 
    include_package_data=True, 
    test_suite='nose2.collector.collector', 
    tests_require=['nose2'], 
    cmdclass={ 
     'clean': CleanCommand, 
    } 
) 

Çıktı kullanarak testler, kurulum script ----- Büyük yazı şimdi için üzgünüm Birinin tavsiyeleriyle tavsiyesinde, onu belirlemek için bir hata ayıklayıcısını kullandım gerçekten de testleri tamamlıyor. Ve gerçekten nerede sıkışmış ise tearDown() sırasında. Aşağıdaki işlev benim sıkıştığı yer. hata ayıklayıcı sonra

def tearDown(self): 
    """Clean db session and drop all tables.""" 
    db.drop_all() 

daha fazla aşağı bunun sonuçta bu yöntem self.traverse_single(table, drop_ok=True, _is_metadata_operation=True) Daha spesifik olarak

for table, fkcs in collection: 
    if table is not None: 
    self.traverse_single(table, drop_ok=True, _is_metadata_operation=True) 
    else: 
    for fkc in fkcs: 
    ... 

sıkışmış tespit edilmiştir. Jeneratörün geri dönmesini beklediğini mi sanıyorum? Emin değilim ama aşağıda tekrar takılmadan önce aldığım son satırlar.

> /Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/SQLAlchemy-1.1.11-py3.6-macosx-10.7-x86_64.egg/sqlalchemy/sql/ddl.py(929)visit_table()->None 
-> _is_metadata_operation=_is_metadata_operation) 
(Pdb) n 
--Call-- 
> /Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/SQLAlchemy-1.1.11-py3.6-macosx-10.7-x86_64.egg/sqlalchemy/sql/visitors.py(150)_visitor_iterator()-><sqlalchemy.s...t 0x112045630> 
-> yield v 
(Pdb) n 
GeneratorExit 
> /Users/XXX/anaconda3/envs/XXX/lib/python3.6/site-packages/SQLAlchemy-1.1.11-py3.6-macosx-10.7-x86_64.egg/sqlalchemy/sql/visitors.py(150)_visitor_iterator()-><sqlalchemy.s...t 0x112045630> 
-> yield v 
(Pdb) l 
145   def _visitor_iterator(self): 
146    """iterate through this visitor and each 'chained' visitor.""" 
147  
148    v = self 
149    while v: 
150 ->    yield v 
151     v = getattr(v, '_next', None) 
152  
153   def chain(self, visitor): 
154    """'chain' an additional ClauseVisitor onto this ClauseVisitor. 
155  
(Pdb) n 

Ben benim şu masaya takılıyor inanıyoruz

from ..helpers import get_current_time 
from ..extensions import db, ma 
from ..constants import STRING_LEN, DESCRIPTION_LEN 
from .worker import WorkerSchema 

class Injury(db.Model): 

    __tablename__ = "injuries" 
    def __repr__(self): 
    return '<Injury %r>' % (self.id) 

    id   = db.Column(db.Integer, primary_key = True) 
    title   = db.Column(db.String(STRING_LEN), nullable=False) 
    description = db.Column(db.String(DESCRIPTION_LEN), nullable=False) 
    worker_id  = db.Column(db.Integer, db.ForeignKey('workers.id')) 
    created_at = db.Column(db.DateTime, nullable=False, default = get_current_time) 
    updated_at = db.Column(db.DateTime, nullable=False, default = get_current_time, onupdate=get_current_time) 

    # Relationships 
    worker = db.relationship('Worker', back_populates='injuries') 

    # ================================================================ 

    # ================================================================ 
    # methods 


    # ================================================================ 
    # Class methods 

    @classmethod 
    def by_id(cls, id): 
    return cls.query.filter(Injury.id==id).first() 

class InjurySchema(ma.Schema): 
    class Meta: 
    fields = ('id', 'title', 'description', 'worker') 

    worker = ma.Nested(WorkerSchema) 
+0

Test takımının problemi ile karşılaştığınız zaman hiç tereddüt etmiyorsanız, burnunuz _which_ işlevi şu anda çalışıyor mu? Öyleyse, sorunuzu bu çıktıyı içerecek şekilde düzenleyebilir misiniz? –

+0

öyle değil, benim konsolumda @JohnGordon gibi neye benzediğimi ekledim ama şu anda yayınladığım iki testin dışında başka test yok –

+0

Def'den önceki sınıf metodu fonksiyonunda bir girinti var, bu doğru mu? – pyCthon

cevap

4

Ben bu yazı SQLAlchemy blocked on dropping tables

def tearDown(self): 
    """Clean db session and drop all tables.""" 
    db.session.close() 
    db.drop_all() 
dayalı benim drop_all komutundan önce db.session.close() ekleyerek işe başardı

Oturumun neden açık olduğunu ve nerede kapatmam gerektiğini hala bulmam gerekiyor