19:03:00 <mtaylor> #startmeeting 19:03:01 <openstack> Meeting started Tue Aug 21 19:03:00 2012 UTC. The chair is mtaylor. Information about MeetBot at http://wiki.debian.org/MeetBot. 19:03:02 <openstack> Useful Commands: #action #agreed #help #info #idea #link #topic #startvote. 19:03:02 <mtaylor> #meetingname CI 19:03:03 <openstack> The meeting name has been set to 'ci' 19:03:15 <mtaylor> oh wel 19:03:16 <jeblair> mtaylor: in general, how about the idea of "#startmeeting ci" 19:03:20 <mtaylor> ++ 19:03:25 <jeblair> mtaylor: and making sure the logs go to /meetings/ci/DATE 19:03:27 <mtaylor> also - now that we have logs.o.o ... 19:03:41 <mtaylor> logs.o.o/meetings/ci/DATE ? 19:03:47 <jeblair> mtaylor: logs.o.o is build logs... 19:03:55 <jeblair> mtaylor: perhaps logs isn't the right name for that 19:04:10 <jeblair> mtaylor: we could change the build logs to "builds.openstack.org" if we want to use "logs" for irc logs 19:04:21 <jeblair> mtaylor: but currently, the host for irc logs is http://eavesdrop.openstack.org/meetings/ 19:04:21 <mtaylor> jeblair: just a thought 19:04:37 <heckj> mtaylor: nope - didn't see that 19:04:38 <jeblair> now's a good time to get all this straight, before we have to add any redirects. :) 19:04:42 <mtaylor> it is - I was just thinking that we don't necessarily have to keep the logs on the same server as the bot 19:04:51 <mtaylor> but I may also be making things more confuseling 19:04:58 <jeblair> mtaylor: oh, er, then we'd have to copy them. 19:05:00 <jeblair> mtaylor: or use afs. 19:05:26 <mtaylor> jeblair: we should totally be using AFS 19:05:54 <jeblair> mtaylor: i think i've just bootstrapped a meetbot test host, so i can work out the details without having to use #openstack-meeting. :) 19:06:15 <mtaylor> neat 19:06:35 <mtaylor> so - that being said ... 19:06:50 <mtaylor> you wanna tell people about logs.o.o (since I know we have tons of onlookers) 19:06:57 <jeblair> sure 19:07:16 <jeblair> clarkb and I have been working on a project to move all of the build logs and reports onto a static html server 19:07:17 * annegentle looks on 19:07:22 <jeblair> http://logs.openstack.org/ 19:07:41 <jeblair> it turns out the more build history and reporting jenkins maintains... 19:07:58 <jeblair> the slower it gets. it's just not meant to scale to the level we're using it at... 19:08:25 <jeblair> so the idea is to put all the build information on the static server 19:08:34 <jeblair> and tell jenkins it doesn't have to keep as much of it around 19:08:53 <jeblair> this also means that developers won't have to log into launchpad and wait 5 minutes to find out why a build failed 19:09:00 <mtaylor> ++ 19:09:06 * mtaylor thinks it will be popular 19:09:11 <jeblair> as we'll link directly from gerrit to logs.o.o when it's all done 19:09:23 <mtaylor> so, when you do that, how will people get pretty reports of their test output? 19:09:35 <jeblair> good question monty! 19:09:54 <jeblair> clarkb is rolling out a nose html output plugin... 19:10:14 <jeblair> and we'll copy an html test report over to logs.o.o 19:10:24 <jeblair> similarly for coverage reports, etc. 19:10:29 <mtaylor> that sounds great! 19:10:33 <jeblair> we've already got the devstack logs copying over 19:10:40 <mtaylor> does it have nifty little javascript controls to expand sections? 19:10:51 <jeblair> clarkb: ? 19:11:08 <jeblair> here's an example set of check jobs for a keystone change: http://logs.openstack.org/11737/1/check/ 19:11:21 <jeblair> (that's the change and patchset numbers in there, so it's easy to find things) 19:11:22 <clarkb> it does 19:11:51 <mtaylor> clarkb: excellent 19:12:22 <mtaylor> now that we have the html output plugin, what's between us and having zuul spit these links into gerrit reviews? 19:12:38 <jeblair> mtaylor: i want to make sure all the jobs are putting all of their data their first 19:12:45 <clarkb> the output will look like the sample here http://tungwaiyip.info/software/sample_test_report.html 19:12:52 <maoy> greetings. :) 19:12:55 <jeblair> mtaylor: basically nothing -- but we have to merge a change into all the projects first 19:13:04 <jeblair> i invited maoy to join us 19:13:14 <jeblair> because he wanted to chat about the pylint job he's working on 19:13:19 <mtaylor> sweet 19:13:25 <mtaylor> #topic pylint 19:13:30 <clarkb> that change is adding the plugin to the test-requires 19:13:54 <mtaylor> ok - wait, before we do pylint... 19:13:58 <mtaylor> do we really need that in test-requires? 19:14:14 <mtaylor> it's not actually a plugin we're expecting devs to run locally, are we? 19:14:24 <maoy> clarkb: are you talking about pylint or something else? 19:14:29 <clarkb> it isn't, but we need the plugin to be installed into the virtual env 19:14:29 <jeblair> mtaylor: no, but we need it to be installed in the venv 19:14:33 <clarkb> maoy: something else 19:14:35 <mtaylor> AH 19:14:38 <mtaylor> bother 19:14:40 <mtaylor> ok 19:14:46 <mtaylor> that's gonna suck 19:14:50 <jeblair> mtaylor: why? 19:14:56 <mtaylor> just merging that everywhere... 19:14:57 <jeblair> mtaylor: isn't that what test-requires is for? 19:15:01 <jeblair> mtaylor: oh, yes. :) 19:15:13 <mtaylor> master, s/e, s/d of all projects 19:15:15 <jeblair> mtaylor: and to stable/* branches too! :) 19:15:16 * mtaylor cries 19:15:38 <mtaylor> we might need to get that in soon before ttx thinks it's a new feature and therefore subject to FF 19:16:29 <clarkb> can we specify the dependency in run-tox somehow? 19:17:16 <jeblair> heh "echo 'nosehtmloutput >> tools/test-requires'" 19:17:21 <jeblair> ^ bad idea, don't do it. 19:17:22 <uvirtbot> jeblair: Error: "bad" is not a valid command. 19:18:16 <mtaylor> that's right uvirtbot ... "bad" is NOT a valid command 19:18:56 <mtaylor> jeblair: "grep nosehtmloutput tools/test-requires 2>&1 || echo 'nosehtmloutput >> tools/test-requires'" 19:19:01 <mtaylor> I think would be more correct 19:19:13 <jeblair> mtaylor: do you want to go down that road? 19:19:18 <mtaylor> jeblair: not REALLY 19:19:34 <mtaylor> but I wouldn't mind if tox could do dependency injection via arguments or env vars... 19:19:43 <jeblair> i think we can propose a bunch of one-liners today 19:19:47 <jeblair> mtaylor: yes, i would like that too. 19:20:00 <mtaylor> we're digressing ... 19:20:04 <mtaylor> pylint! 19:20:09 <mtaylor> maoy: hey there 19:20:13 <maoy> yo 19:20:23 <jeblair> maoy: so your question to me... 19:20:37 <jeblair> maoy: was whether we could have pylint report to gerrit but not count its vote 19:20:37 <maoy> https://jenkins.openstack.org/job/gate-nova-pylint/32/console 19:20:57 <maoy> this is what it looks like when there is a bug, pretty sweet 19:21:03 <jeblair> maoy: is that something you want to do in the long run, or do you still want it to eventually be a real gating job? 19:21:45 <maoy> jeblair: hard to say.. might not be that a bad idea to do it for a few months.. 19:21:54 <maoy> in openstack i guess that's "long"? :) 19:22:10 <jeblair> http://logs.openstack.org/11444/9/silent/gate-nova-pylint/32/console.html 19:22:19 <jeblair> there's the new static url for that. :) 19:22:27 <jeblair> maoy: (that was our previous meeting topic) 19:22:42 <mtaylor> that's SO MUCH QUICKER to load 19:22:49 <maoy> oh. i c.. 19:22:58 <maoy> https://jenkins.openstack.org/job/gate-nova-pylint/32/violations/file/nova/utils.py/? 19:23:09 <maoy> anything static for this type? 19:23:45 <jeblair> maoy: no... remeber in the code review i mentioned i would like either an html or formatted text report? 19:23:54 <jeblair> maoy: this is why 19:24:12 <maoy> jeblair: yup. this is really nice.. 19:24:38 <maoy> jeblair: i can stand it being this slow. :) 19:24:47 <maoy> not very very slow. :) 19:24:57 <jeblair> maoy: so if you output something nice to the console, or to a separate html or txt file, we can copy it over. 19:25:17 <clarkb> pylint has an html output format 19:25:20 <jeblair> maoy: i'm not clear -- are you saying you prefer slow and the pretty jenkins output? 19:25:23 <mtaylor> jeblair: so - a generalized pylint and pep8 output format to html converter... 19:25:26 <mtaylor> or what clarkb said 19:25:28 <jeblair> clarkb: yes, but maoy's script hides it 19:25:44 * mtaylor shuts up - jeblair and clarkb have things well in hand 19:26:21 <maoy> clarkb: jeblair is right. I had to parse pylint's output so no html from pylint. 19:26:38 <maoy> jeblair: I think the current output format is good enough for me. :) 19:27:03 <maoy> jeblair: but I wonder if it's possible to link the result of this to Jenkin's comment in Gerrit. 19:27:37 <jeblair> maoy: so why not turn it on as a gate job when it's ready? 19:28:17 <maoy> jeblair: that would take a while for people to get comfortable with it as a gate job I guess. 19:28:55 <jeblair> maoy: do you think people are going to pay attention to it if it's not a gate job? 19:29:22 <maoy> jeblair: I think so. For example, smokestack is not gate job per se 19:29:39 <maoy> but it's a warning sign 19:30:36 <maoy> but I guess it's not some existing function that's already available to use in Jenkins, right? 19:30:38 <jeblair> i just remember people not ever really caring if they increased the pylint count, unless we gated on it, and the one project we were gating on pylint eventually got tired of it. 19:30:57 <clarkb> as a quick hack to get parsable output and html can you simply run pylint twice? 19:31:20 <mtaylor> clarkb: he needs to filter the already seen errors from the output 19:31:32 <clarkb> ah 19:31:38 <jeblair> maoy: correct, it's not an existing feature; it would be a (fairly small) change to zuul to do that. 19:31:40 <maoy> ckarkb: mtaylor is right. but we do have parsable output now 19:32:58 <jeblair> maoy: if we think that's the way we want to go, i can add that to zuul 19:33:37 <jeblair> mtaylor: you were around in the old pylint days, what do you think? 19:34:16 <maoy> the spectrum is silent pipeline -> warning in jenkins -> gate function. 19:34:17 * LinuxJedi suddenly imagines mtaylor dressed as Obiwan 19:34:36 <jeblair> LinuxJedi: what's oubiwann wearing then? 19:34:38 <maoy> at the moment it seems I have enough headwind to do it as a gate function 19:35:30 <LinuxJedi> jeblair: a dusty old cloak, and talks about the good old days when he turned boys evil or something 19:35:54 <maoy> but silent pipeline seems a bit too silent.. 19:36:02 <jeblair> so the change to zuul would be that an individual job could be marked as non-voting, so it could be included in the check and gate pipelines, but its vote isn't counted when determining whether to run the success or failure actions. 19:36:24 <maoy> jeblair: that's exactly what I was hoping for.. 19:36:47 <jeblair> zuul would report "gate-nova-pylint: FAILURE", but if nothing else failed, the overall verified status would still be +1 or +2. 19:37:07 <clarkb> is that much better than simply running it as a check test and not a gate test? 19:37:13 <clarkb> I would be worried about confusing people 19:37:38 <jeblair> clarkb: that's a good idea too, but that would mean a -1 verified vote on check, and the same change could get a +2 verified vote on gate... 19:37:58 <maoy> clarkb: interesting. I haven't thought about that.. 19:38:20 <jeblair> clarkb: that's also a change in how the system currently works... anyone who ignores verified=-1 changes would be disrupted by that 19:38:26 <jeblair> clarkb: but otherwise, does make a lot of sense. 19:38:49 <maoy> jeblair: good pt. might slightly confusing.. 19:39:05 <clarkb> ya I think either way some education has to happen. 19:39:14 <LinuxJedi> probably would have made more sense in a 0-2 rating on verified 19:39:22 <clarkb> so picking the less painful route which appears to be not counting a test against the verified vote is the way to go 19:39:56 <jeblair> we can annotate the test in the message with "non-voting" or something if that's helpful. 19:40:06 <LinuxJedi> ++ 19:40:16 <maoy> or is it possible for jenkins to post another comment separately just to show pylint result as FYI? 19:40:38 <LinuxJedi> the way gerrit works that would initially hide one or the other comment 19:40:45 <jeblair> maoy: and it generates email, so we try to keep the number of comments down 19:40:56 <LinuxJedi> that too :) 19:41:01 <maoy> got it.. 19:41:38 <jeblair> okay, so i think we're all leaning toward the non-voting test solution.... 19:41:47 <maoy> +1 on that 19:41:56 <jeblair> maoy: i'll work that up and point you at the change when it's ready 19:42:27 <maoy> jeblair: thanks much. i'll talk to other nova folks to see their opinion. 19:42:43 <maoy> jeblair: one thing is that pylint job does take a while to run.. not sure if it matters 19:43:22 <clarkb> tempest currently takes about 15 minutes I think 19:43:24 <jeblair> maoy: it takes about as long as the unit tests, and we run all the jobs in parallel, so there's no net change 19:43:35 <jeblair> and yeah, tempest takes even longer. :) 19:43:45 <maoy> cool.. 19:43:57 <jeblair> maoy: we even test multiple changes in parallel (that's what zuul is all about) 19:44:23 <maoy> btw, there is some change in lintstack 19:44:43 <maoy> previously there is a pylint_exception committed in the source tree to record what errors have been seen before 19:44:46 <LinuxJedi> now we just need to work on a way of testing changes before people write them 19:45:12 <maoy> in the new code, that file is auto generated from HEAD~1 every time so there is no need to maintain that 19:45:12 <jeblair> LinuxJedi: easy "tox && /bin/false". they all fail. 19:45:18 <LinuxJedi> lol :) 19:45:34 <jeblair> maoy: that may be a problem. 19:46:00 <maoy> https://review.openstack.org/#/c/11444/9/tools/lintstack.sh 19:46:19 <maoy> that's how I deal with it now.. 19:47:21 <jeblair> maoy: that makes some assumptions about the state of the git tree that may not be correct. 19:47:53 * jeblair is thinking 19:49:10 <mtaylor> jeblair: actually - interestingly enough - if you have a sequence of merges 19:49:28 <mtaylor> jeblair: shouldn't the first merge in the sequence throw the pylint error, but then others in the sequence not? 19:50:07 <maoy> are you guys thinking about merges with multiple parents? 19:50:09 <jeblair> so the thing i'm considering is... 19:50:27 <mtaylor> maoy: no, we do a lot of things in support of parallel testing 19:50:54 <jeblair> well, i am also thinking of merge commits 19:50:59 <jeblair> what if HEAD is a merge commit? 19:51:03 <mtaylor> me. that too 19:51:05 <mtaylor> mmm. that too 19:51:15 <jeblair> (it usually is, currently) 19:51:16 <maoy> oh. you mean the files could be in use by other tests, like the unit tests? 19:51:39 <jeblair> maoy: let's talk about that in a second -- first let's focus on "HEAD is a merge commit" 19:51:57 <jeblair> maoy: you are comparing HEAD to HEAD~1... 19:52:29 <jeblair> maoy: wouldn't that compare the commit "Merge 'my change'" with "my change" 19:52:42 * mtaylor believes jeblair is correct 19:53:15 <maoy> not really.. see the git logs here: https://jenkins.openstack.org/job/gate-nova-pylint/32/console 19:53:37 <maoy> somehow it's fast-forwarded so HEAD is not a merge commit 19:53:49 <jeblair> maoy: i mean, it might compare "Merge 'my change'" with "the previous head", but that depends on the order of the parent commits, which i'm not sure is guaranteed. 19:54:20 <jeblair> maoy: we fast-forward if possible, but that's only possible if you have rebased immediately before testing 19:54:33 <jeblair> maoy: otherwise, we merge, which is usually what happens when changes actually land 19:54:42 <jeblair> maoy: see the commit history here: https://github.com/openstack/nova/commits/master 19:54:53 <maoy> jeblair: it seems that git review is doing that rebase automatically now 19:55:01 <jeblair> maoy: yes. and that's actually about to change 19:55:10 <jeblair> maoy: future versions won't do that anymore. 19:55:34 <jeblair> i think we're about to run out of time.. 19:55:39 <maoy> jeblair: ok.. so what should I compare to against HEAD if not HEAD~1? 19:55:44 <jeblair> maybe we should continue this conversation in #openstack-infra 19:56:04 <mtaylor> I think next step here is that we need to test the HEAD v. HEAD~1 logic in some different scenarios 19:56:20 <mtaylor> and also continue the discussion in #openstack-infra 19:56:24 <maoy> agree 19:56:52 <mtaylor> k. I'm calling it 19:56:52 <maoy> I have to leave for half an hour around 4pm EDT (i.e. in 5 minutes).. 19:57:01 <mtaylor> #endmeeting