<div dir="ltr"><div class="gmail_default" style="font-size:small"><br></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Mar 26, 2014 at 6:24 PM, Doug Hellmann <span dir="ltr"><<a href="mailto:doug.hellmann@dreamhost.com" target="_blank">doug.hellmann@dreamhost.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div style="font-size:small"><br></div><div class="gmail_extra"><br><br><div class="gmail_quote"><div><div class="h5">
On Wed, Mar 26, 2014 at 4:30 PM, James E. Blair <span dir="ltr"><<a href="mailto:jeblair@openstack.org" target="_blank">jeblair@openstack.org</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi,<br>
<br>
I recently started looking into running the unit tests with MySQL. I<br>
pushed the start of a change here to do that:<br>
<br>
<a href="https://review.openstack.org/#/c/82872/" target="_blank">https://review.openstack.org/#/c/82872/</a><br>
<br>
In particular, that change implements something we've wanted to do for a<br>
long time elsewhere in OpenStack -- create a dedicated MySQL database<br>
for each test so that tests can safely run in parallel. However, that<br>
has uncovered the following issues:<br>
<br>
* The tests do not use alembic, except for the migration test. This<br>
could lead to variations in what the unit tests are testing against<br>
as compared to production.<br>
<br>
* The model does not specify an engine for MySQL (this is a difference<br>
between the model and the alembic migrations). So when the unit tests<br>
are run on MySQL, they may end up on MyISAM (they do in the gate).<br>
<br>
* The two errors that show up in the test results for my patch relate<br>
to how timestamps are stored differently between MySQL and SQLite.<br>
<br>
* The errors that you can not see in the test report from Jenkins but<br>
would if you ran in an environment with InnoDB as the default engine<br>
for MySQL are several instances of foreign key constraint errors.<br>
<br>
I think it is desirable to run the unit tests with MySQL largely because<br>
I think we should be testing it in the way we intend to use it in<br>
production. Note especially the last point above -- our unit tests have<br>
significant problems with MySQL. That suggests one of two things to me:<br>
either the tests aren't testing real behavior, or our system is actually<br>
broken in production. Neither one seems like a good situation.<br>
<br>
My inclination would be to use MySQL for unit tests, use alembic to<br>
create the schema, and fix the errors currently uncovered by this.<br>
<br>
It's not going to be a trivial change, but I think it's worth doing.<br>
Before embarking on it, I'd like to see if we can get consensus. We can<br>
talk about it here or possibly at the meeting tomorrow.<br>
<br>
Ruslan has commented in that review with the following:<br>
<br>
> But, I think that we should consider work done in major OpenStack<br>
> projects. They don't use real MySQL to run unit-tests. Here is what<br>
> the do (or plan to do):<br>
><br>
> * Run unit-tests on SQLite. DB schema is created from SQLA metadata<br>
> * Run DB migration tests on MySQL and Postgres<br>
> * Run tests to compare SQLA metadata and DB migrations to make sure<br>
> that they're in sync. Here is WIP patch<br>
> <a href="https://review.openstack.org/#/c/" target="_blank">https://review.openstack.org/#/c/</a><br>
><br>
> I'm not opposed to this direction, I just want to make sure we're<br>
> aligned with the common practices in OpenStack<br>
<br>
(That last link doesn't seem to be correct.)<br>
<br>
That's a good point, but I personally find testing as close to<br>
production as possible desirable -- MySQL and SQLite are not compatible<br>
so we shouldn't pretend that they are. If we prove this is a viable<br>
strategy, then I think we should recommend OpenStack projects adopt it<br>
as well.<br></blockquote><div><br></div></div></div><div><div style="font-size:small">Some of the folks from Mirantis who are working on oslo.db are working on making it so we can use the models to create a database in our unit tests, and then compare the resulting database with what the migrations do. That *should* speed up tests, since we don't have to apply a set of migrations, while still ensuring that we are testing using the same schema. It also has the benefit of ensuring that our models represent what the migrations create. I've copied Victor and Roman on this so they can add more detail.</div>
</div></div></div></div></blockquote><div><br></div><div><div class="gmail_default" style="font-size:small">And, that's the same work Ruslan was linking to based on his follow-up message.</div><div class="gmail_default" style="font-size:small">
<br></div><div class="gmail_default" style="font-size:small">Doug</div><br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_extra">
<div class="gmail_quote"><div><span class="HOEnZb"><font color="#888888">
<div style="font-size:small"><br></div><div style="font-size:small">Doug</div><br></font></span></div><div class=""><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
-Jim<br>
<br>
_______________________________________________<br>
OpenStack-Infra mailing list<br>
<a href="mailto:OpenStack-Infra@lists.openstack.org" target="_blank">OpenStack-Infra@lists.openstack.org</a><br>
<a href="http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-infra" target="_blank">http://lists.openstack.org/cgi-bin/mailman/listinfo/openstack-infra</a><br>
</blockquote></div></div><br></div></div>
</blockquote></div><br></div></div>