<div dir="ltr"><div>Sorry, <br></div>Full code bellow:<br><p id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136788" dir="ltr">class MyShellCommand(shell.<wbr>ShellCommand):<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136802"><br> def __init__(self, **kwargs):<br> shell.ShellCommand.__init__(self, **kwargs)<br> self.addLogObserver('stdio', logobserver.LineConsumerLogObserver(self.logConsumer))<br> self.testFailed = False<br></p><p dir="ltr"> def logConsumer(self):<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136803"> while True:<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136804"> stream, line = yield<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136805"> if line.find('TEST_FAILURE_<wbr>INDICATOR') != -1:<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136806"> self.testFailed = True</p><p dir="ltr" id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136857"> return</p><p dir="ltr" id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136856"> def evaluateCommand(self, cmd):<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136907"> res = shell.ShellCommand.<wbr>evaluateCommand(self, cmd)<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136908"> if self.testFailed:<br id="gmail-m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136909"> res = FAIL</p><br></div><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Mar 1, 2018 at 2:55 PM, Cipi Bad <span dir="ltr"><<a href="mailto:cipibad@gmail.com" target="_blank">cipibad@gmail.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"><p id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136964">Hi,</p><p id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136960"></p><p id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136952">Something like bellow should work.</p><p id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136956"></p><p>BR,</p><p>cipibad<br></p><p id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136957"></p><p id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136788" dir="ltr">class MyShellCommand(shell.<wbr>ShellCommand):<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136802"> def logConsumer(self):<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136803"> while True:<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136804"> stream, line = yield<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136805"> if line.find('TEST_FAILURE_<wbr>INDICATOR') != -1:<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136806"> self.testFailed = True</p><p dir="ltr" id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136857"> return</p><p dir="ltr" id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136856"> def evaluateCommand(self, cmd):<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136907"> res = shell.ShellCommand.<wbr>evaluateCommand(self, cmd)<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136908"> if self.testFailed:<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136909"> res = FAILURE<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136910"> return res<br id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136916"><br></p><p id="m_-1153500495053923540gmail-yui_3_16_0_ym19_1_1519282469693_136787"><span><br class="m_-1153500495053923540gmail-yui-cursor"></span></p><br></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Thu, Mar 1, 2018 at 2:04 PM, Martin Liška <span dir="ltr"><<a href="mailto:mliska@suse.cz" target="_blank">mliska@suse.cz</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 would consider it handy to run a command and make an output analysis<br>
in LineConsumerLogObserver. Doing that I would like to fail a build step,<br>
is it somehow possible?<br>
<br>
Thanks,<br>
Martin<br>
______________________________<wbr>_________________<br>
users mailing list<br>
<a href="mailto:users@buildbot.net" target="_blank">users@buildbot.net</a><br>
<a href="https://lists.buildbot.net/mailman/listinfo/users" rel="noreferrer" target="_blank">https://lists.buildbot.net/mai<wbr>lman/listinfo/users</a><br>
</blockquote></div><br></div>
</div></div></blockquote></div><br></div>