summaryrefslogtreecommitdiff
AgeCommit message (Collapse)Author
2009-09-15Fix ' git bz attach' failure when bugzilla server has a pathJonathon Jongsma
I had accidentally prepended the bugzilla installation path in both BugServer.send_post() and BugServer.send_request() (which is called by send_post()), so the path was getting prepended twice when trying to attach a patch.
2009-09-15Fix exception when parsing an alias as a urlJonathon Jongsma
In BugHandle.parse(), we first try to parse the bug reference as a url and then fall back to interpreting it as an alias from the config file. Unfortunately, something like "gnome:123456" gets parsed as a url (with a scheme of 'gnome' and a path of '123456', and no hostname). This resulted in us passing a None hostname to tracker_get_auth_user(), which resulted in an uncaught exception. From now on, only proceed with treating the bug reference as a url if the scheme is parsed as 'http' or 'https'.
2009-09-11Add support for bugzilla installations that require http authJonathon Jongsma
This patch should support http authentication credentials specified in url form (e.g. https://user:password@foo.com) or in a configuration file. The additional configure options are: - bz-tracker.<alias>.authuser - bz-tracker.<alias>.authpwd
2009-09-11Add support for bugzilla installations in non-root pathsJonathon Jongsma
Currently, git-bz assumes that all bugzilla installations are at the root of the host (e.g. http://foo.com/). It is currently impossible to use git-bz with a bugzilla installation that is hosted at e.g. foo.com/bugzilla/. This patch adds that ability. A new configuration option ('bz-tracker.alias.path') allows the path to be specified for a host.
2009-09-09Mark bugzilla.gnome.org as httpsOwen W. Taylor
bugzilla.gnome.org now supports and redirects to https; even though we handle the redirects, having it as https in the config will save a round trip.
2009-09-09Handle redirectsOwen W. Taylor
Handle redirect HTTP responses, in particular if a Bugzilla server is redirecting from http to https. We try to detect "Bugzilla URL base is over here" when we ask for show_bug.cgi and remember that for future requests to the same BugServer to avoid too many redirections. Switch from caching connection on the BugServer to a global connection cache, and rewrite the BugServer cache so to deal with the possibility of redirections.
2009-09-09Avoid Python2.6-ismsEmmanuele Bassi
I'm not entirely up to speed with the new syntax of Python 2.6, but apparently you can now do: func(*args, named_arg=value, **options) and: func(*args, named_arg=value) and Python will happily coalesce named_arg into **options for you. This is not a valid syntax for Python 2.5, though.
2009-09-05Add 'git bz push -fix' and 'git bz edit --fix'Owen W. Taylor
Add one-stop-shopping --fix=<bug reference> options to 'git bz push' and 'git bz edit'. These combine attaching the patches and resolving the bug for cases where review and testing aren't necessary.
2009-09-05Make 'git bz add-url' more like git rebaseOwen W. Taylor
Instead of resetting the branch and applying the patches there, move to a detached HEAD, apply patches to the detached HEAD and then make a single update to the branch ref. The only real advantage of this is that 'git reflog show <branchname>' shows a single meaningful commit.
2009-09-05TODO updatesOwen W. Taylor
- Always do 'git bz attach --edit' - Apply patches as a single mailbox - Make -u/--add-url kinder on the reflog
2009-09-05Split out documentationOwen W. Taylor
Move the documentation from a giant comment at the start of the file into a separate asciidoc document. Among other revisions an 'EXAMPLE SESSION' section is added to give a sense of the normal workflow. Add a Makefile and asciidoc.conf for converting the asciidoc into HTML or a man page.
2009-09-05Command line option tweaksOwen W. Taylor
- Remove the -p shortcut for 'git bz edit --pushed' - I don't find it sufficiently mnemonic to be worth confusion with things like 'git add -p'. - Say -n/--no-add-url instead of just --no-add-url in an error message. - Fix usage messages to consistently use () for grouping and [] for optional parts.
2009-09-05Allow omitting bug reference for 'git bz attach'Owen W. Taylor
When there is a single bug referenced in the commits being attached, allow using that instead of specifying a bug reference manually.
2009-09-04Make --add-url the default for 'git bz apply' as wellOwen W. Taylor
1) It's confusing to have it different 2) For git bz push, we want to have that association whenever possible, even if you didn't create the patch yourself.
2009-09-04Ignore committed/rejected patchesOwen W. Taylor
If patches have a status and it's 'committed' or 'rejected', then skip them for git-bz apply and don't prompt.
2009-09-01Allow configuring bug reference additionOwen W. Taylor
Allow configuring the behavior of add-url and --add-url with the bz.add-url-method config variable. For example: git config bz.add-url-method subject-prepend:Bug %d -
2009-09-01Improve URL additionOwen W. Taylor
* Avoid false positives when the bug # is a substring of a number in the commit. * Look at the header, not just the body, for an existing bug # * When there are local changes, don't print the diffs to the the screen. * For 'git bz add-url' indicate what commits we are skipping, and don't prompt if we aren't going to do anything. * Don't start the rebase procedure if we aren't going to do anything.
2009-09-01Add URLs by defaultOwen W. Taylor
Switch the default for 'git bz file' and 'git bz attach' so that they automatically add the URL to the commit message. Add -n/--no-add-url options to disable adding the URL.
2009-08-31Make bug changes before attachment changes to avoid token problemsOwen W. Taylor
If we make attachment changes first, we change the timestamp of the bug; rather than refetching a new token for the bug (or parsing it out of the HTML response), we just make the bug changes first and the attachment changes second.
2009-08-31Use .add() for sets not .append()Owen W. Taylor
Fix a problem with adding patches to the 'unapplied_patches' set.
2009-08-31Cache legal field valuesOwen W. Taylor
Use our constant-field-value cache to cache legal field values for each server; this cuts round trips for 'git bz edit' from 3 to 1, which is quite noticeably faster. The legal_values method is moved from Bug to BugServer, where it makes more sense.
2009-08-31Add utility for constant-response cachingOwen W. Taylor
We don't want to constantly refetch things like legal field values from the server. Add a simple cache based on RawConfigParser and pickled values stored in ~/.git-bz-cache.
2009-08-31Add push subcommand to help commandOwen W. Taylor
When listing the available commands, include 'push'
2009-08-31Fix checking for missing fields in XML responseOwen W. Taylor
token = bug.find("token") self.token = token.text if token else None Was behaving strangely: apparently ElementTree can be logically false when non-None. Switch to the more explicit: self.token = None if token is None else token.text
2009-08-30Fix marking patches as obsolete from 'git bz edit'Owen W. Taylor
Field value for isobsolete must be string "1" not 1.
2009-08-30Fix git-bz to work with none-GNOME bugzillaOwen W. Taylor
* Catch the server returning a 500 protocol error on xmlrpc.cgi; this happens with bugzilla.openedhand.com and probably other older versions of post 3.0 bugzilla. * Handle the server not sending bug/attachment tokens * Make patch-status handling conditional on the server having status on patches.
2009-08-30Add 'git bz edit --pushed' and 'git bz push'Owen W. Taylor
'git bz edit --pushed <commits>' automatically prepares the bug editing buffering based on a guess as what edits (comments, resolving the bug, changing attachment status) are appropriate once the commits are pushed to the project's official repository. 'git bz push' actually pushes commits and then does 'git bz edit --pushed'
2009-08-30Allow capturing stderr from a run git commandOwen W. Taylor
If _return_error=True is added to git.<command_name>() then a tuple of captured output from stderr, stdout is returned. We'll need this to parse the output of 'git push' which goes to stderr.
2009-08-30Allow passing a commit or revision range to 'git bz edit'Owen W. Taylor
If a commit or revision range is passed to 'git bz edit', make it edit all the bugs referenced in the commit or commits.
2009-08-30Add a BugHandle class to represent parsed bug referencesOwen W. Taylor
Instead of using (host, https, id) tuples, encapsulate the information in a BugHandle class. Add get_bug_server() method to look up a server for a (host, https) pair; we uniquify the server across multiple lookups; this will be useful if we edit multiple bugs in a single run.
2009-08-30Add an edit subcommandOwen W. Taylor
git bz edit <bug reference> Allows doing common operations on a Bugzilla bug without going to your web browser. An editable buffer is brought up in a git-like fashion, where you can add comments, resolve a bug, and change the status of patches. This is really a warm-up for 'git bz push' which will do a semi-automatic job of figuring out all the appropriate edits that need to be made when pushing a set of commits that are annotated with bug references.
2009-08-30Add a method for getting legal field valuesOwen W. Taylor
Add Bug.legal_values() to query the server via XML-RPC to find out legal values for a particular field.
2009-08-30Add a method to update a patch on a bugOwen W. Taylor
Add Bug.update_patch() to allow changing fields of an existing attachment (status, isobsolete, etc.) This requires saving all the fields when parsing them out of the bug XML, since we have to pass them back to attachment.cgi.
2009-08-30Add a method to update a bugOwen W. Taylor
Add Bug.update() to allow changing fields in an existing bug. (adding comments, setting the status/resolution, etc.)
2009-08-30Add helper functions for handling abbrevationsOwen W. Taylor
abbreviation_help_string(['apple', 'pear', 'potato']) => '[a]pple, [pe]ar, [po]tato' expand_abbreviation('pea', ['apple', 'pear', 'potato']) => 'pear'
2009-08-30Add a helper function for checking for successOwen W. Taylor
Encapsulate the process of grepping through successful (200) responses from Bugzilla to see if they were *really* successful in a function.
2009-08-29Allow files=None for BugServer.send_post()Owen W. Taylor
We only want to pass in a non-None files in one place, so allow files=None to be the same as {}.
2009-08-29File bugs via XML-RPC when possibleOwen W. Taylor
If the server supports XML-RPC (3.0 or newer), then filing via xmlrpc.cgi has advantages: - We get a string error message instead of an HTML page - We can not specify priority/severity and let the server default it; this is important since there aren't standard priorities. So, we try to first file via xmlrpc.cgi's Bug.create method and if we get a 404, fall back to the old method of a form post. The configuration for a couple of fields is changed to use the human readable field names from Bug.create rather than the database-field names of post_bug.cgi. default-bug-severity => default-severity default-rep-platform => default-platform
2009-08-29Split HTTP communication out of Bug classOwen W. Taylor
Create a separate BugServer class that represents a Bugzilla server instance and has send_request()/send_post() methods.
2009-08-29Fix error message when not logged inOwen W. Taylor
A string with unsubstituted %s was being printed; substitute in the host and browser properly. Pointed out by Jonathon Jongsma
2009-08-29Improve error handling when bug reference is incorrectJonathon Jongsma
If the user specifies the bug url on the command line but the url violates our assumptions, git-bz doesn't currently handle it well. For instance, the following commandline invocation: git bz attach http://bugzilla.foo.org HEAD will fail the regex that checks whether it is a bugzilla url (since it is missing show_bug.cgi), so it will interpret it as a 'alias:1234'-style reference. 'http' is interpreted as the alias, but when that is not found in the git config, it will attempt to look up a browser cookie for the host 'http'. That will also fail, but it will report a misleading error which is something like: Please log in to 'http' in Firefox This patch just does a little sanity checking that the bug id is a number and aborts with a slightly more helpful error message if that is not true.
2009-08-24Fix to work again with FirefoxOwen W. Taylor
The version of Colin's Chromium patch I applied was outdated and had an obvious left-over in the Xulrunner codepaths that made things no longer with with Firefox and Epiphany. Fix.
2009-08-24Support chromium cookiesColin Walters
Chromium uses sqlite for cookies as well and with a very similar (but not identical) schema compared to xulrunner. Abstract things a bit so that chromium can use most of the same code.
2009-08-24Get attachment data from XML bug dump instead of downloading separatelyOwen W. Taylor
All of the bugtrackers we care about (gnome,mozilla,freedesktop,openedhand), include attachment data in the ctype=xml output, so: - Use excludefield=attachmentdata when we don't want attachment data - Use the data downloaded with the XML data when we do want attachment data (git bz apply) rather than downloading it separately. This fixes problems with bugzilla servers that use a redirect for attachments.
2009-08-15Fix to work with Bugzilla 3.4Owen W. Taylor
Bugzilla 3.4 (like the new GNOME bugzilla) - Requires a status for attached patches - Uses a different title for succesful attachments
2009-06-25Pass -M to git-format-patchOwen W. Taylor
Passing -M to git-format-patch when creating patches means that renames will be shown as renames, increasing reviewability of the resulting patches.
2009-04-25Make 'git bz file <commit>' just file that commitOwen W. Taylor
Deviate from git-format-patch in the handling of a single revision: file a bug with a single patch is definitely more common than filing a bug with a range of patches and this results in less mystical invocations. Hopefully git-format-patch will eventually catch up. Remove the support for --num=<N> and -N since it's minimally useful now; it's not impossible to want to do 'git bz file old_commit^.. -2' but I don't want to clutter the interface.
2009-04-25Move default-product and default-component to main bz sectionOwen W. Taylor
Picking up product and component from the tracker specific config was never useful and annoying; move the options bz.default-product and bz.default-component. Display useful help when product/component aren't specified. (No concession to backwards-compat here: people can easily reconfigure, especially with the help.)
2009-04-25Work around Firefox-3.5 locking problems with a copyOwen W. Taylor
Firefox-3.5 seems to always hold cookies.sqlite locked while the browser is open. Work around this by, when we hit a lock error, making a copy and reading from that. Not 100% reliable, but should work much of the time.
2009-04-25Factor out common code between Firefox and Epiphany cookie readingOwen W. Taylor
Make both call a common get_cookies_from_sqlite() to avoid code duplication. Return errors by raising a CookieError so that we can centralize information about git-config bz.browser into one place.