<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Mon, Jun 30, 2014 at 8:33 PM, Sören Gebbert <span dir="ltr"><<a href="mailto:soerengebbert@googlemail.com" target="_blank">soerengebbert@googlemail.com</a>></span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi Vaclav,<br>
<br>
2014-06-30 17:43 GMT+02:00 Vaclav Petras <<a href="mailto:wenzeslaus@gmail.com">wenzeslaus@gmail.com</a>>:<br>
<div class="">> Hi,<br>
><br>
> when writing tests which involve PyGRASS Module class I found that at some<br>
> occasions the error messages are quite confusing.<br>
><br>
> First when you try to run one module twice, you get AttributeError:<br>
><br>
>>>> from grass.pygrass.modules import Module<br>
>>>> from subprocess import PIPE<br>
>>>> m = Module('<a href="http://r.info" target="_blank">r.info</a>', map='elevation', run_=False, stdout_=PIPE)<br>
>>>> m.run()<br>
>>>> m.outputs['stdout'].value<br>
> ...<br>
>>>> # running for the second time<br>
>>>> m.run()<br>
> Traceback (most recent call last)<br>
>     ...<br>
> AttributeError: 'str' object has no attribute 'fileno'<br>
<br>
</div>That should be fixed in r61083. Reason was the wrong handling of<br>
stderr and stdout ,<br>
the PIPE was overwritten when the module finished.<br>
<div class=""><br></div></blockquote><div>Thanks.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="">
><br>
> Second, when you confuse m.inputs['map'].value with m.inputs['map'] (which<br>
> is pretty easy error to do) you get "TypeError: deletions are implemented<br>
> differently for unicode":<br>
><br>
>>>> # this is OK<br>
>>>> m.inputs['map'].value = 5<br>
> Traceback (most recent call last)<br>
>     ...<br>
> TypeError: The Parameter <map>, require: raster, get: <type 'int'> instead<br>
>>>> # this is not OK<br>
>>>> # confusing parameter object and parameter value<br>
>>>> m.inputs['map'] = 'aspect'<br>
> Traceback (most recent call last)<br>
>     ...<br>
> TypeError: deletions are implemented differently for unicode<br>
<br>
</div>This is indeed a misleading error report. I do not have a solution right away,<br>
but i would suggest to use always the __call__ function when<br>
specifying an option:<br>
<br>
color = Module("r.colors", run_=False)<br>
color(map="test")<br>
color(color="gyr")<br>
color.run()<br>
color(map="test2", color="ryb")<br>
color.run()<br>
<div class=""><br></div></blockquote><div>I must get used to this one.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="">
> With the former it depends what is actually allowed. Than it is probably<br>
> easy to fix. With the later, no easy solutions come to my mind.<br>
><br>
> With my tests I was actually asserting m.outputs['stdout'] for true which is<br>
> always true instead of asserting m.inputs['stdout'].value. I don't know how<br>
> to avoid this mistake in general.<br>
<br>
</div>We should avoid in general to set the option values directly, instead<br>
the __call__ function should be used<br>
which is much safer.<br>
<div class=""><br>
> Does this make sense to you or do you think that I and PyGRASS users should<br>
> be just be more careful?<br>
<br>
</div>The error report must be modified to be more meaningful. I would<br>
suggest to overwrite the assignment function "=" (if this is<br>
possible???) of the Parameter class to catch such errors. The<br>
assignment method will work in case of a Parameter object and raise a<br>
meaningful error in case anything else. Does this sounds reasonable?<br>
<br></blockquote><div>I must admit that I'm not sure whose assignment operator is called. Parameters, or the function for adding item to the dictionary? Assignment operator cannot be overloaded in Python. So, it seems that it must the the later. So, the only solution is TypeDict which is already used. I'm confused. Now focusing on something else.<br>

<br></div><div>Thanks,<br></div><div>Vaclav<br></div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Best regards<br>
Soeren<br>
<br>
><br>
> Vaclav<br>
</blockquote></div><br></div></div>