[openstack-qa] On refactoring of base classes/infrastructure

Jay Pipes jaypipes at gmail.com
Thu Feb 21 15:22:21 UTC 2013


On 02/20/2013 11:03 PM, Daryl Walleck wrote:
> There's been a lot of interest around modifying the base test classes in
> Tempest, which is something that without a doubt needs to be explored.
> Before doing that, I'd like to make sure we're thinking of what the
> problem we're trying to solve is by doing this and what the final
> solution should look like. I think we can all agree on these things:
> 
>   * We need something to prepare test configuration
>   * Something to manage resources generated from tests
>   * A means to load all necessary clients for testing

Yep, agreed.

> Where I started to get concerned was when I noticed the number of
> classes we needed to inherit from just to enable basic functionality.
> Going through the class model again brought up some other difficulties:
> 
>   * The openstack module has grown to the point of being unwieldy

Agreed.

>   * We load every client for every test regardless of the product

Actually, it's not that we load every client that bothers me. It's that
we break clients out unnecessarily to begin with. I would vastly prefer
to have a single file for compute JSON client and a single file for
compute XML client (per major version of course). Having dozens of these
little clients is silly, IMHO.

>   * It's not necessarily clear what belongs in each level of base test class
> 
> It seems like we could handle some of our complexity through aggregates
> and breaking things down into smaller pieces. I also think base test
> classes might not be the right term in some cases, as they're really
> more of high level fixtures. Just my thoughts, but here's what I
> sketched out.
> 
> http://imgur.com/fqD01OT

Other than the split out of multiple client files/classes, I think this
is good. It looks virtually identical to the proof of concept I put
together that uses the fixtures.Fixture and
testresources.ResourceTestCase classes as bases:

https://github.com/jaypipes/tempest/blob/api/tempest/fixtures/identity.py
https://github.com/jaypipes/tempest/blob/api/tempest/tests/api/base.py

with this test case showcasing the approach:

https://github.com/jaypipes/tempest/blob/api/tempest/tests/api/compute/test_flavors.py

Best,
-jay



More information about the openstack-qa mailing list