Python SQLAlchemy - Mocking a model attribute's “desc” method

后端 未结 2 1620
悲&欢浪女
悲&欢浪女 2021-02-01 10:50

In my application, there is a class for each model that holds commonly used queries (I guess it\'s somewhat of a \"Repository\" in DDD language). Each of these classes is passed

相关标签:
2条回答
  • 2021-02-01 11:32

    I don't think you're really gaining much benefit by using mocks for testing your queries. Testing should be testing the logic of the code, not the implementation. A better solution would be to create a fresh database, add some objects to it, run the query on that database, and determine if you're getting the correct results back. For example:

    
    # Create the engine. This starts a fresh database
    engine = create_engine('sqlite://')
    # Fills the database with the tables needed.
    # If you use declarative, then the metadata for your tables can be found using Base.metadata
    metadata.create_all(engine)
    # Create a session to this database
    session = sessionmaker(bind=engine)()
    
    # Create some posts using the session and commit them
    ...
    
    # Test your repository object...
    repo = PostRepository(session)
    results = repo.find_latest()
    
    # Run your assertions of results
    ...
    

    Now, you're actually testing the logic of the code. This means that you can change the implementation of your method, but so long as the query works correctly, the tests should still pass. If you want, you could write this method as a query that gets all the objects, then slices the resulting list. The test would pass, as it should. Later on, you could change the implementation to run the query using the SA expression APIs, and the test would pass.

    One thing to keep in mind is that you might have problems with sqlite behaving differently than another database type. Using sqlite in-memory gives you fast tests, but if you want to be serious about these tests, you'll probably want to run them against the same type of database you'll be using in production as well.

    0 讨论(0)
  • 2021-02-01 11:34

    If yet you want to create a unit test with mock input, you can create instances of your model with fake data

    In case that the result proxy return result with data from more than one of the models (for instance when you join two tables), you can use collections data struct called namedtuple

    We are using it to mock results of join queries

    0 讨论(0)
提交回复
热议问题