<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Fri, Mar 21, 2014 at 9:38 AM, Malini Kamalambal <span dir="ltr"><<a href="mailto:malini.kamalambal@rackspace.com" target="_blank">malini.kamalambal@rackspace.com</a>></span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5"><br>
<br>
On 3/21/14 12:01 PM, "David Kranz" <<a href="mailto:dkranz@redhat.com">dkranz@redhat.com</a>> wrote:<br>
<br>
>On 03/20/2014 04:19 PM, Rochelle.RochelleGrober wrote:<br>
>><br>
>>> -----Original Message-----<br>
>>> From: Malini Kamalambal [mailto:<a href="mailto:malini.kamalambal@RACKSPACE.COM">malini.kamalambal@RACKSPACE.COM</a>]<br>
>>> Sent: Thursday, March 20, 2014 12:13 PM<br>
>>><br>
>>> 'project specific functional testing' in the Marconi context is<br>
>>> treating<br>
>>> Marconi as a complete system, making Marconi API calls & verifying the<br>
>>> response - just like an end user would, but without keystone. If one of<br>
>>> these tests fail, it is because there is a bug in the Marconi code ,<br>
>>> and<br>
>>> not because its interaction with Keystone caused it to fail.<br>
>>><br>
>>> "That being said there are certain cases where having a project<br>
>>> specific<br>
>>> functional test makes sense. For example swift has a functional test<br>
>>> job<br>
>>> that<br>
>>> starts swift in devstack. But, those things are normally handled on a<br>
>>> per<br>
>>> case<br>
>>> basis. In general if the project is meant to be part of the larger<br>
>>> OpenStack<br>
>>> ecosystem then Tempest is the place to put functional testing. That way<br>
>>> you know<br>
>>> it works with all of the other components. The thing is in openstack<br>
>>> what<br>
>>> seems<br>
>>> like a project isolated functional test almost always involves another<br>
>>> project<br>
>>> in real use cases. (for example keystone auth with api requests)<br>
>>><br>
>>> "<br>
>>><br>
>>> One of the concerns we heard in the review was 'having the functional<br>
>>> tests elsewhere (I.e within the project itself) does not count and they<br>
>>> have to be in Tempest'.<br>
>>> This has made us as a team wonder if we should migrate all our<br>
>>> functional<br>
>>> tests to Tempest.<br>
>>> But from Matt's response, I think it is reasonable to continue in our<br>
>>> current path & have the functional tests in Marconi coexist  along with<br>
>>> the tests in Tempest.<br>
>>><br>
>> I think that what is being asked, really is that the functional tests<br>
>>could be a single set of tests that would become a part of the tempest<br>
>>repository and that these tests would have an ENV variable as part of<br>
>>the configuration that would allow either "no Keystone" or "Keystone" or<br>
>>some such, if that is the only configuration issue that separates<br>
>>running the tests isolated vs. integrated.  The functional tests need to<br>
>>be as much as possible a single set of tests to reduce duplication and<br>
>>remove the likelihood of two sets getting out of sync with each<br>
>>other/development.  If they only run in the integrated environment,<br>
>>that's ok, but if you want to run them isolated to make debugging<br>
>>easier, then it should be a configuration option and a separate test job.<br>
>><br>
>> So, if my assumptions are correct, QA only requires functional tests<br>
>>for integrated runs, but if the project QAs/Devs want to run isolated<br>
>>for dev and devtest purposes, more power to them.  Just keep it a single<br>
>>set of functional tests and put them in the Tempest repository so that<br>
>>if a failure happens, anyone can find the test and do the debug work<br>
>>without digging into a separate project repository.<br>
>><br>
>> Hopefully, the tests as designed could easily take a new configuration<br>
>>directive and a short bit of work with OS QA will get the integrated FTs<br>
>>working as well as the isolated ones.<br>
>><br>
>> --Rocky<br>
>This issue has been much debated. There are some active members of our<br>
>community who believe that all the functional tests should live outside<br>
>of tempest in the projects, albeit with the same idea that such tests<br>
>could be run either as part of today's "real" tempest runs or mocked in<br>
>various ways to allow component isolation or better performance. Maru<br>
>Newby posted a patch with an example of one way to do this but I think<br>
>it expired and I don't have a pointer.<br>
><br>
>IMO there are valid arguments on both sides, but I hope every one could<br>
>agree that functional tests should not be arbitrarily split between<br>
>projects and tempest as they are now. The Tempest README states a desire<br>
>for "complete coverage of the OpenStack API" but Tempest is not close to<br>
>that. We have been discussing and then ignoring this issue for some time<br>
>but I think the recent action to say that Tempest will be used to<br>
>determine if something can use the OpenStack trademark will force more<br>
>completeness on tempest (more tests, that is). I think we need to<br>
>resolve this issue but it won't be easy and modifying existing api tests<br>
>to be more flexible will be a lot of work. But at least new projects<br>
>could get on the right path sooner.<br>
><br>
>  -David<br>
><br>
><br>
>_______________________________________________<br>
>OpenStack-dev mailing list<br>
><a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
><a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
<br>
</div></div>We are talking about different levels of testing,<br>
<br>
1. Unit tests - which everybody agrees should be in the individual project<br>
itself<br>
2. System Tests - 'System' referring to (& limited to), all the components<br>
that make up the project. These are also the functional tests for the<br>
project.<br>
3. Integration Tests - This is to verify that the OS components interact<br>
well and don't break other components -Keystone being the most obvious<br>
example. This is where I see getting the maximum mileage out of Tempest.<br></blockquote><div><br></div><div>Its not easy to detect what the integration points with other projects are, any project can use any stable API from any other project. Because of this all OpenStack APIs should fit into this category. </div>

<div> </div><div>Having a second group writing tests to Nova's public APIs has been really helpful in keeping us honest as well.</div><div><br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">


<br>
I see value in projects taking ownership of the System Tests - because if<br>
the project is not 'functionally ready', it is not ready to integrate with<br>
other components of Openstack.<br></blockquote><div><br></div><div>What do you mean by not ready?</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
But for this approach to be successful, projects should have diversity in<br>
the team composition - we need more testers who focus on creating these<br>
tests.<br>
This will keep the teams honest in their quality standards.<br>
<br>
As long as individual projects cannot guarantee functional test coverage,<br>
we will need more tests in Tempest.<br>
But that will shift focus away from Integration Testing, which can be done<br>
ONLY in Tempest.<br>
<br>
Regardless of whatever we end up deciding, it will be good to have these<br>
discussions sooner than later.<br>
This will help at least the new projects to move in the right direction.<br>
<span class="HOEnZb"><font color="#888888"><br>
-Malini<br>
</font></span><div class="HOEnZb"><div class="h5"><br>
<br>
<br>
<br>
<br>
<br>
<br>
<br>
_______________________________________________<br>
OpenStack-dev mailing list<br>
<a href="mailto:OpenStack-dev@lists.openstack.org">OpenStack-dev@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-dev</a><br>
</div></div></blockquote></div><br></div></div>