=== spiv_ is now known as spiv | ||
poolie | hi all | 01:10 |
---|---|---|
spiv | Hi poolie | 01:13 |
poolie | hi spiv | 01:13 |
poolie | spiv, today, starting quite soon, i'm going to try to improve the broken lock bug | 01:13 |
spiv | bug 619872? | 01:14 |
ubot5 | Launchpad bug 619872 in Bazaar "bzr: ERROR: exceptions.ValueError: tag/value separator not found in line '' reading lockdir info file (affected: 1, heat: 6)" [Medium,Confirmed] https://launchpad.net/bugs/619872 | 01:14 |
poolie | sorry, no, the failure to release locks when we're interrupted | 01:14 |
spiv | Ah, good, because I'm working on 619872 :) | 01:15 |
poolie | great | 01:15 |
poolie | so you said the file is full of nuls? or has a nul? | 01:15 |
spiv | Well, rio.read_stanza(['\0']) is the minimal way to reproduce that exact error text. | 01:15 |
spiv | But any number of nuls would do it too. | 01:16 |
poolie | :/ | 01:16 |
poolie | i'm glad we know why it's happening but that's a bit disturbing | 01:16 |
poolie | i wonder how they get in there? | 01:16 |
spiv | (pedant: any natural number...) | 01:16 |
poolie | ooh, that's high grade pedantry | 01:16 |
poolie | :) | 01:16 |
poolie | it reminds me of the other duped bug that was active recently where the dirstate file is truncated | 01:16 |
poolie | well, it's not very similar, but both are "don't trust the filesystem too much" | 01:17 |
spiv | I think some filesystems like XFS have been known to leave files full of nuls after a crash? | 01:17 |
poolie | many unix things can | 01:17 |
poolie | if the inode update is not strictly ordered with writing data | 01:17 |
poolie | xfs may be more prone too it | 01:17 |
poolie | some have had the bug that you could get bits of other files | 01:18 |
poolie | but that's a bit of a security bug and should be uncommon | 01:18 |
spiv | Right. And ext3/4 has a bunch of different options that affect that sort of thing. | 01:18 |
spiv | The original bug report in this case appears to be windows. | 01:19 |
* fullermd supposed you mean "... appears to be ON windows", but it's funnier read the other way 8-} | 01:24 | |
poolie | hi spiv, teddy? | 05:13 |
poolie | i'm getting in to the locking bugs | 05:14 |
poolie | i might try just closing a terminal with bzr running, holding a lock | 05:14 |
poolie | and see what signal it gets and what it does after that | 05:14 |
lifeless | bam | 05:14 |
poolie | presumably sighup | 05:14 |
poolie | ? | 05:14 |
lifeless | mental image | 05:14 |
lifeless | row of bzr's lined up | 05:15 |
lifeless | in terminals | 05:15 |
lifeless | and a firing squad | 05:15 |
poolie | mm | 05:15 |
lifeless | trying to get them at just the right moment | 05:15 |
lifeless | <- strange | 05:15 |
lifeless | I think thats a great way to get a handle on what is happening to python/bzr | 05:15 |
poolie | in some ways i think coping with broken locks by detecting them and asking if you want to steal them, would be better | 05:16 |
lifeless | something you may have already considered is adding some instrumentation to capture in .bzr.log signal info | 05:16 |
lifeless | poolie: we should definitely do that for same-machine locks | 05:16 |
poolie | i know | 05:16 |
* lifeless was emitting moral support | 05:17 | |
spiv | poolie: I'm pretty sure it's SIGHUP | 05:17 |
spiv | poolie: I did an experiment along those lines a while back, registering a SIGHUP handler in a simple python script, blocking on raw_input(), then closing the terminal | 05:18 |
poolie | it is | 05:18 |
poolie | i'm not confident that unwinding will really fix all cases but it's worth a try | 05:19 |
spiv | Hmm, if you want to be fancy you could subclass KeyboardInterrupt as SIGHUPInterrupt, and raise that from a SIGHUP handler. All code that expects to let KeyboardInterrupt propagate would still work, and then at the top level you could potentially distinguish from KI in cause you didn't want to print 'bzr: interrupted' or whatever. | 05:20 |
lifeless | poolie: one more suggesting | 05:22 |
lifeless | poolie: when stealing, we should run some recovery / check code for half-done alterations to the repository in particular (think pack-names). | 05:22 |
poolie | good idea spiv | 05:31 |
poolie | and lifeless | 05:31 |
poolie | i might hook it from library_state.py | 05:31 |
CcxCZ | hi, I managed to break bzr http://paste.pocoo.org/show/257906/ | 07:10 |
CcxCZ | all I did was 'bzr remove --keep <DIR>' for a dir with versioned files and then it all went breaking here and there | 07:13 |
spiv | CcxCZ: hmm, that sounds familiar | 07:24 |
spiv | CcxCZ: hmm, sounds like another instance of https://bugs.edge.launchpad.net/bzr/+bug/377261 | 07:28 |
ubot5 | Launchpad bug 377261 in Bazaar ""AssertionError: name u'COMPILING' already in parent" in _generate_inventory when running "bzr update" (affected: 4, heat: 2)" [High,Confirmed] | 07:28 |
spiv | CcxCZ: FWIW I can't reproduce with simple experiments locally with 'bzr remove --keep' of a dir, if you can figure out a recipe to reproduce your scenario that would be very helpful | 07:31 |
spiv | CcxCZ: also there's a comment on https://bugs.edge.launchpad.net/bzr/+bug/504836 (a dupe of 377361) that may help you recover | 07:32 |
ubot5 | Launchpad bug 504836 in Bazaar "AssertionErorr "name .. already in parent" during _generate_inventory (dup-of: 377261)" [Undecided,New] | 07:32 |
ubot5 | Launchpad bug 377261 in Bazaar ""AssertionError: name u'COMPILING' already in parent" in _generate_inventory when running "bzr update" (affected: 4, heat: 2)" [High,Confirmed] | 07:32 |
CcxCZ | ok, I'll mark myself affected and I'll post my dirstate | 07:35 |
spiv | CcxCZ: thanks! Please give as much info as you can about how you got into this state, e.g. any uncommitted changes or merges before you ran bzr remove --keep. | 07:36 |
vila | hi all ! | 07:41 |
spiv | Hi vila | 07:47 |
vila | \o_ | 07:47 |
CcxCZ | spiv: submitted. Right now I don't have time to try to reproduce it, but I have the state archived. | 07:55 |
=== spm` is now known as spm | ||
spiv | CcxCZ: great, thank you! | 08:08 |
poolie | spiv, so as i feared, once we try handling sighup as an exception, we get back into ERESTARTSYS | 08:44 |
poolie | hi vila? | 08:53 |
vila | poolie: hey ! | 08:53 |
poolie | hey there, how are you? | 08:53 |
vila | poolie: I'm fine | 08:54 |
poolie | i just saw, catching up on my mail from last week, that the january epic is already settled | 08:54 |
poolie | that's truly epic organization :) | 08:54 |
vila | ;) | 08:54 |
vila | Yeah, found your pm only this morning, we need to discuss before end of September (we should have booked the flights by then) | 08:57 |
spiv | poolie: :/ | 08:58 |
spiv | poolie: one option would be a C module like https://code.edge.launchpad.net/~spiv/bzr/sigwinch-without-signalmodule-583941 proposed, or only enabling this on sufficiently new CPython. (>= 2.6.6, IIRC) | 09:00 |
spiv | (2.6.6 is the version where signal.siginterrupt actually works) | 09:00 |
poolie | :/ | 09:01 |
poolie | that seems like quite a heavy solution considering that this probably won't fix most unlocking cases | 09:01 |
spiv | IIRC the C module would provide basically the same behaviour as Python gives us for SIGINT | 09:01 |
poolie | i feel a bit more convinced now it would be better to just let the lock break and then cope gracefully later | 09:01 |
vila | poolie: as in better stealing a broken lock ? | 09:02 |
spiv | FWIW I'm trying to be pretty rigorous with tests and corner cases with my lock work atm. | 09:02 |
poolie | vila, yes- | 09:02 |
poolie | spiv, i'm glad, but what's the connection? | 09:02 |
vila | poolie: lock :) | 09:03 |
poolie | ? | 09:03 |
spiv | Well, coping with perhaps damaged locks, e.g. incompletely written. | 09:03 |
poolie | oh ok | 09:03 |
poolie | i was just confused because in the cases i'm thinking about, there's not much we can do about them | 09:04 |
poolie | these are stale locks left behind by bzr dying, or the connection dropping | 09:04 |
spiv | Right. | 09:04 |
poolie | or, for example, it being killed by sighup | 09:04 |
spiv | My hope is that what I'm working on will make the recovery from those situations very reliable, because as you say they are hard to avoid. (And in the worst case the network connection drops midway and there's nothing bzr can do to tidy up the interrupted op) | 09:06 |
spiv | Or after a messy system crash. | 09:07 |
spiv | It's a bit of a shame to have to code to cope gracefully with non-bzr things failing, but that's life :) | 09:07 |
poolie | oh, maybe we're overlapping then? | 09:08 |
poolie | i was going to put this aside and give you a ui to break locks interactively | 09:08 |
poolie | and to detect locks probably owned by dead processes | 09:08 |
spiv | Hmm, I don't think there's much overlap, I think probably what I'm doing is more complementary. | 09:09 |
spiv | Partly test coverage, partly giving better exceptions in previously unexpected cases. | 09:09 |
spiv | Anyway, it's past 6 on a Friday, and V is letting me know by reaching for my laptop, so I should go :) | 09:11 |
poolie | :) | 09:13 |
poolie | i hope you're all getting better? | 09:13 |
vila | meh, how can "error: (32, 'Broken pipe')" be uncaught by a "except (OSError, IOError), e:" ? | 09:22 |
vila | err, followed by: if e.errno not in (errno.EPIPE,): | 09:23 |
vila | raise | 09:23 |
poolie | vila, i'm guessing it's actually a socket.error | 09:26 |
poolie | which is a different beast | 09:26 |
poolie | annoyingly | 09:26 |
poolie | i think that's what it was | 09:26 |
vila | gimme my bazaar.launchpad,net back | 09:36 |
poolie | i know! | 09:36 |
vila | ha, planned hardware maintenance: http://identi.ca/launchpadstatus/ | 09:37 |
vila | one hour to go | 09:37 |
vila | hmm, I can delay writes, but reads...WIBNI a read-only version was always available... | 09:39 |
vila | poolie: hmm, socket.error, sounds like it. We have some latent bugs then | 09:43 |
poolie | there's a bug asking for readonly mode | 09:44 |
poolie | though if it's a hardware fix, this might be a case where we can't do it | 09:44 |
poolie | there's also a bug about socket.error | 09:44 |
poolie | vila, i'm thinking of giving the ui a concept of "does the user want interaction on topic x" | 09:45 |
poolie | then we can just turn that off for break-lock | 09:45 |
poolie | indeed perhaps that's overcomplicated and they just want "is this interactive at all?" | 09:46 |
vila | poolie: yup, that matches up with having config variables accepting y/n/ask instead of being pure boolenas | 09:46 |
vila | booleans even damn delete key being too close to enter ;) | 09:47 |
vila | I thought about that recently, we ould then have a '-y' generic option that would always reply yes without any user interaction | 09:47 |
vila | s/ould/could/ | 09:48 |
poolie | right, i'm thinking we should just have that poke some state in to the ui factory | 09:48 |
poolie | we could also add configuration options to control them | 09:48 |
vila | yup, that could be implemented as a ui factory, which will be well suited for script usage | 09:49 |
vila | then you could chose between the config variable and the generic option or any combination that fits | 09:50 |
poolie | should we have a separate concept of asking whether you want to be interactive, or should the core ui code perhaps just ask "should i break the lock" | 10:05 |
poolie | it's a bit look-before-you-leap | 10:05 |
poolie | vila, what do you think of http://pastebin.ubuntu.com/487726/ | 11:09 |
poolie | i might sign off in a bti | 11:09 |
vila | poolie: at first glance: I was thinking of a specific type for config values but I don't have a clear answer about how that should interact with the ui factory, having to register all interaction messages won't scale right | 11:13 |
vila | I think the idea was that the code still calls get_boolean, but if the value is 'ask' then the user is prompted, unless the ui is non-interactive | 11:15 |
vila | that doesn't say what the default should be though, but I think get_boolean can already return None | 11:16 |
vila | I kind of feel that the message and the default value should stay in the caller code... | 11:16 |
poolie | it seems useful to me to put the message into the ui so that guis or whatever can present it differently | 11:18 |
vila | poolie: and when I mentioned the '-y' option, I was vaguely thinking about a '--no' option too, but the consequences are unclear... | 11:18 |
poolie | rather than just getting a string | 11:18 |
vila | right, and i18n issues too, but doesn't get_boolean accept a prompt parameter (or should it ?) | 11:18 |
poolie | i was going to then make the ui look up that value in the config | 11:18 |
poolie | it does take a prompt parameter | 11:19 |
poolie | but it folds the other parameters in to it | 11:19 |
poolie | whereas really we want to do i18n before that | 11:19 |
vila | Well, if we reach the point where every constant is a config variable, then, msgs are constants... | 11:21 |
poolie | so what do you think? | 11:22 |
vila | so your idea will fly too but turning all messages into constants... will not rejoice everybody :-/ | 11:22 |
poolie | heh, i wouldn't like that | 11:23 |
poolie | but i have a feeling that ui interactions are a bit different | 11:23 |
poolie | i suppose you're right though that it does make things more indirect that you can't just put them inline in the code | 11:23 |
vila | I think I prefer get_boolean(prompt=xxx) rather than interaction_messages, the prompt is indeed an interaction message | 11:23 |
poolie | i think for setting interactivity and defaults | 11:26 |
vila | to step back a bit, my primary example was uncommit's 'Are you sure' , where I'd like a config variable | 11:26 |
poolie | and for letting the ui do something smarter than just showing the string | 11:27 |
poolie | we want a symbolic name, not just a string to match against | 11:27 |
poolie | but perhaps not? | 11:27 |
vila | err, as far as config variables are concerned, strings *are* symbolic names | 11:27 |
poolie | so what would you anticipate having in the config file? | 11:28 |
poolie | "Are you sure" = no? | 11:28 |
vila | ho no ! You mean that get_boolean is called with a prompt and without referring to a config variable | 11:28 |
poolie | i thought that's what you were asking for | 11:29 |
vila | in this case, we need config.get_uncommit_xxx() which implementation check for a conf var and fallback to get_boolean('Are you sure') | 11:29 |
vila | to ui.get_boolean('Are you sure') so GUIs still have a chance to trigger | 11:30 |
poolie | i'd like to keep it at still just one line for application code | 11:33 |
poolie | so how about ui.get_boolean('Really uncommit?', id='bzr.uncommit.confirm') | 11:34 |
vila | could be: config.get_user_option('bzrlib.builtins.cmd_uncommit.confirm') hehe | 11:35 |
poolie | heh, something like that | 11:35 |
vila | aliases could be defined | 11:35 |
poolie | and then the other thing to change is to put the variables to insert into it as kwargs to the ui factory | 11:36 |
vila | so, it depends on whether config can use ui or the opposite | 11:36 |
poolie | right | 11:36 |
poolie | i could go either way | 11:36 |
poolie | but i think of ui as being a somewhat higher-level thing | 11:37 |
vila | so far I think there is only get_user_option_as_bool that uses config, I don't know if ui uses config | 11:37 |
vila | I don't know, a user should be able to configure the ui to use but that doesn't forbid all uis to implement all the needed features | 11:38 |
poolie | istm that making them symbolic would also possibly help later with testing | 11:39 |
vila | The uis use env variables which can be seen as config vars as well | 11:39 |
poolie | right, they should be unified | 11:39 |
vila | indeed, partly by defining where they are in the config layering and partly by defining either aliases (to the corresponding config var) or a rule to go from one to the other | 11:41 |
poolie | just keeping things at a more symbolic layer rather than going straight down to strings would be good | 11:42 |
poolie | oh, rules from env variables to config things? yes | 11:42 |
vila | yes | 11:42 |
vila | I think my (slight) disagreement is the same regarding the show_xxx and warn_xxx additions to ui, my feeling is that this shouldn't be part of ui but stay in application code | 11:44 |
vila | I understand the benefits to group them in a single place but... dunno, something feels wrong | 11:45 |
poolie | do you mean things like show_cross_format_fetch? | 11:48 |
vila | yes | 11:48 |
poolie | ah ok, so show_user_warning is already going in this direction isn't it, of having a warning_id | 11:48 |
vila | by the way, 'bzrlib.builtins.cmd_uncommit.confirm' is accepted as a key by configobj (I just checked) | 11:49 |
vila | that's what I'm saying, yes | 11:49 |
poolie | ok | 11:50 |
vila | on the other hand, we also have a config.suppress_warnings | 11:50 |
vila | which is to say, we may need more data points to triangulate :) | 11:51 |
poolie | ok so it seems like we agree there should be an id passed through | 11:51 |
poolie | and the arguments should be separate | 11:51 |
=== poolie changed the topic of #bzr to: Bazaar version control | try https://answers.launchpad.net/bzr for more help | http://irclogs.ubuntu.com/ | Patch pilot: jam | bzr 2.2.0 is out | ||
poolie | (still needs an announcement i think) | 11:52 |
vila | and this id is probably the config var | 11:52 |
poolie | right | 11:52 |
poolie | so there's the question of whether the standard text for it should be inline in the caller | 11:53 |
vila | stepping back to the application code, I want a boolean, I may describe its intent to the user with a string (which could be the docstring for the default value of the config var) | 11:53 |
poolie | which will make it easy to see how to add new ones | 11:53 |
vila | hehe | 11:53 |
poolie | ok? | 11:54 |
vila | all this proposals came from my thinkings about config vars to be honest | 11:54 |
poolie | i think it would be nice to have purely declarative stuff for config vars | 11:55 |
poolie | no methods per var | 11:55 |
vila | exactly | 11:55 |
poolie | except those that have a calculated default | 11:55 |
vila | even them | 11:55 |
poolie | and then describe where it's read from and what env var it may map to | 11:55 |
poolie | well, no method, just a callable | 11:55 |
poolie | so in this particular one | 11:55 |
poolie | we can declare them essentially inline at the place that uses them | 11:55 |
poolie | which may be reasonable if they are mostly used from one call site | 11:56 |
poolie | or we could have a central registry | 11:56 |
vila | not even a callable, we can manage to have declarations in bzrlib.config or just a registry so anybody can declare them inline | 11:56 |
vila | hehe | 11:56 |
poolie | well, if it's for example determined by reading /etc/mailname then at some level there needs to be a callable | 11:56 |
vila | right, the default value can be a callable | 11:57 |
vila | which in turn can use othe conf vars, haha, only serious | 11:57 |
vila | and of course plugins can override the default value... endless fun | 11:58 |
poolie | ok, so | 11:58 |
vila | in this context, the user can speak too, hence the 'ask' special value | 11:58 |
poolie | adding id and args parameters to get_boolean and friends is a small change for the callers | 11:59 |
poolie | and probably makes it maximally easy to implemetn new uis | 11:59 |
vila | ohhhhh, yeah ! That's the ui side ! | 11:59 |
vila | hmm, so the conf var docstring can be a format, hence the kwargs | 12:00 |
poolie | then i guess if for some thing we want to take the default text out of the application code, we could just make the text parameter optional | 12:00 |
poolie | what's the conf var docstring? | 12:00 |
vila | <poolie> so there's the question of whether the standard text for it should be inline in the caller | 12:00 |
vila | <vila> stepping back to the application code, I want a boolean, I may describe its intent to the user with a string (which could be the docstring for the default value of the config var) | 12:00 |
poolie | hm, and where would that be in the code? | 12:01 |
vila | I don't know if this will work for all cases but the ui level don't have to care | 12:01 |
vila | in the registry | 12:01 |
vila | that is, if you use conf vars, you pass the docstring to the ui | 12:02 |
vila | if you get straight to the ui, well, you provide it, so it will be inline in the caller | 12:02 |
vila | if you go straight to the ui, well, you provide it, so it will be inline in the caller | 12:03 |
vila | when you said ui higher than config, I thought, well, orthogonal | 12:03 |
poolie | so do you still see the app code calling a method on the ui? | 12:06 |
vila | if there is no config variable, yes | 12:06 |
poolie | i would have thought we'd have a clear distinction between things that are meant to behave like config variables, and things that are possibly user interactions | 12:06 |
vila | ISTM that some/most? of the user interactions can be linked to a conf var | 12:07 |
poolie | mm, but i think specifically blocking and asking the user something needs to be taken account in the code in a way that looking up a config variable does not | 12:08 |
poolie | maybe not | 12:08 |
vila | warnings about format deprecations, confirming uncommit, forcing push/pull/commit | 12:08 |
vila | that's why I say conf vars, newbies may want to be asked whether their push is valid, experienced users hate that | 12:09 |
poolie | oh, i definitely agree that should be configurable | 12:09 |
poolie | i just think that the intent of the app code is "here's something to possibly warn about" not "look up a configuration variable" | 12:09 |
vila | hmm | 12:10 |
poolie | ok | 12:11 |
poolie | i'm tired; i should stop | 12:11 |
vila | but the code flow may depends on the user answer or a conf var... I don't have a definitive answer, both config and ui are involved it may be clearer for the application code to refer to ui, may be the call itself should be ui and the parameters from config, or just hidden in the call | 12:12 |
poolie | istm there are going to be a number of callers | 12:13 |
poolie | and we want them to have the simplest experience we can | 12:13 |
poolie | so at least a facade that covers up checking with either config or the ui | 12:13 |
vila | sounds good | 12:15 |
=== ddaa1 is now known as ddaa | ||
=== rml_ is now known as rml | ||
starenka | hi can i hook a shell script which would be executed on the server as soon a rev is pushed to it? (bzr+ssh) | 13:25 |
=== Ursinha is now known as Ursinha-lunch | ||
=== Ursinha-lunch is now known as Ursinha | ||
=== basic_ is now known as basic` | ||
=== beuno is now known as beuno-lunch | ||
jam | starenka: look into the "post_branch_tip_changed" hook. It is a python hook, but you can have it hook into a script | 18:11 |
jam | I think jelmer also had a plugin that exposed bzr hooks to shell scripts | 18:11 |
=== beuno-lunch is now known as beuno | ||
starenka | jam: thanks | 19:08 |
=== james_w` is now known as james_w | ||
=== deryck is now known as deryck[lunch] | ||
=== deryck[lunch] is now known as deryck | ||
C-S | For all the guys who asked for testtools on FreeBSD... Here it is: http://www.freshports.org/devel/py-testtools/ | 20:31 |
C-S | Just ported it and it got accepted today :-) | 20:31 |
C-S | this is in particular news for fullermd :-) | 20:32 |
jelmer | C-S: \o/ | 20:57 |
C-S | jelmer: what you guys wanted, right? | 20:57 |
jelmer | C-S: Well, I don't use FreeBSD but it's great to have testtools available on more systems. | 20:58 |
C-S | jelmer: You should give it a try! FreeBSD is just a dream :-) | 20:58 |
jelmer | :) | 21:13 |
jelmer | I've used it in the past and quite like it | 21:13 |
fullermd | C-S: Sweet :) | 21:17 |
=== _thumper_ is now known as thumper |
Generated by irclog2html.py 2.7 by Marius Gedminas - find it at mg.pov.lt!