Zac Medico [Sun, 15 Aug 2010 16:27:38 +0000 (09:27 -0700)]
Remove unuser return values from PollScheduler event handlers.
Zac Medico [Sun, 15 Aug 2010 16:17:17 +0000 (09:17 -0700)]
Remove redundant os.path.join() call in _init_ipc_fifos().
Zac Medico [Sun, 15 Aug 2010 16:13:19 +0000 (09:13 -0700)]
Add the "unexpected bash exit" case to the docstring.
Zac Medico [Sun, 15 Aug 2010 08:39:40 +0000 (01:39 -0700)]
Add some ebuild metadata for realism.
Zac Medico [Sun, 15 Aug 2010 08:18:19 +0000 (01:18 -0700)]
Pass along PORTAGE_USERNAME and PORTAGE_GRPNAME since they
need to be inherited by ebuild subprocesses.
Zac Medico [Sun, 15 Aug 2010 08:12:11 +0000 (01:12 -0700)]
Make create_trees() pass along PORTAGE_GRPNAME and PORTAGE_USERNAME
to all config instances.
Zac Medico [Sun, 15 Aug 2010 08:05:26 +0000 (01:05 -0700)]
Avoid KeyError if PORTAGE_USERNAME or PORTAGE_GRPNAME are unset.
Zac Medico [Sun, 15 Aug 2010 07:57:30 +0000 (00:57 -0700)]
Pass along PORTAGE_USERNAME and PORTAGE_GRPNAME inside _load_config()
since since they need to be inherited by ebuild subprocesses.
Zac Medico [Sun, 15 Aug 2010 07:41:08 +0000 (00:41 -0700)]
Add some more info to the 'Cannot chown a lockfile' message, since
it's being triggered on the buildbot.
Zac Medico [Sun, 15 Aug 2010 07:14:10 +0000 (00:14 -0700)]
Set PORTAGE_PYTHON for ebuild.sh subprocesses.
Zac Medico [Sun, 15 Aug 2010 07:07:36 +0000 (00:07 -0700)]
DoebuildSpawnTestCase: Invoke portage.package.ebuild.doebuild.spawn()
with a minimal environment. This gives coverage to some of the ebuild
execution internals, like ebuild.sh, EbuildSpawnProcess, and
EbuildIpcDaemon.
Zac Medico [Sun, 15 Aug 2010 05:18:17 +0000 (22:18 -0700)]
Bug #332799 - Don't download lzma snapshots if tarsync is installed.
Zac Medico [Sun, 15 Aug 2010 03:11:57 +0000 (20:11 -0700)]
Disable EbuildIpcDaemon for now, since it seems to be triggering
intermittent build failures in my stage builds. For testing purposes
set PORTAGE_IPC_DAEMON_ENABLE=1 to enable EbuildIpcDaemon.
Sebastian Luther [Sat, 14 Aug 2010 23:24:24 +0000 (01:24 +0200)]
portage.dep: Integrate the functionality of flatten into use_reduce
Zac Medico [Sat, 14 Aug 2010 18:37:31 +0000 (11:37 -0700)]
Add support for NOCOLOR variable.
Zac Medico [Sat, 14 Aug 2010 18:15:36 +0000 (11:15 -0700)]
Merge branch 'master' of git+ssh://git.overlays.gentoo.org/proj/portage
Zac Medico [Sat, 14 Aug 2010 18:13:01 +0000 (11:13 -0700)]
Pass $USE via IPC in order to ensure that we have the correct value for
built/installed packages, since the config class doesn't currently provide
a way to access built/installed $USE that would work in all possible
scenarios.
Arfrever Frehtes Taifersar Arahesis [Sat, 14 Aug 2010 18:04:03 +0000 (20:04 +0200)]
Use more correct paths to byte-compiled Python modules with Python 3.2
and remove empty __pycache__ directories.
Zac Medico [Sat, 14 Aug 2010 17:46:57 +0000 (10:46 -0700)]
Fix the ACCEPT_LICENSE setting that's generated for eutils check_license()
to account for package.license.
Zac Medico [Sat, 14 Aug 2010 17:21:45 +0000 (10:21 -0700)]
When in background mode, set NOCOLOR=true in order to prevent color
codes from showing up in logs, since we're not displaying to a terminal
anyway. Thanks to Brian Harring for the suggestion.
Zac Medico [Sat, 14 Aug 2010 17:05:42 +0000 (10:05 -0700)]
Add PORTAGE_PYTHON to _environ_whitelist.
Zac Medico [Sat, 14 Aug 2010 17:01:55 +0000 (10:01 -0700)]
Move PORTAGE_PYTHON setting to doebuild_environment() so that it
doesn't pollute os.environ.
Zac Medico [Sat, 14 Aug 2010 16:37:43 +0000 (09:37 -0700)]
Move 'phase' attribute to AbstractEbuildProcess from subclasses, so
the _get_phase() method isn't needed.
Zac Medico [Sat, 14 Aug 2010 16:20:49 +0000 (09:20 -0700)]
Add a QueryCommand.settings attribute and use it so that $USE
doesn't have to be passed to the daemon in has_version and
best_version calls.
Zac Medico [Sat, 14 Aug 2010 15:25:45 +0000 (08:25 -0700)]
Fix EbuildSpawnProcess to use self.settings.environ() for the spawn
environment, so all AbstractEbuildProcess subclasses are consistent
in this way.
Sebastian Luther [Sat, 14 Aug 2010 14:34:25 +0000 (16:34 +0200)]
portage.dep: Integrate the functionality of dep_opconvert into use_reduce
Zac Medico [Sat, 14 Aug 2010 07:58:25 +0000 (00:58 -0700)]
Make sure PORTAGE_IPC_DAEMON is only in the environment for
appropriate phases (it was leaking into clean/cleanrm from
previous phases.
Zac Medico [Sat, 14 Aug 2010 07:13:58 +0000 (00:13 -0700)]
Fix _schedule spelling in _schedule_waitpid().
Zac Medico [Sat, 14 Aug 2010 07:10:07 +0000 (00:10 -0700)]
Add a PollScheduler._schedule_waitpid() method for SubProcess._wait()
to use as an alternative to hanging up the scheduler in a blocking
waitpid call.
Sebastian Luther [Sat, 14 Aug 2010 06:43:34 +0000 (08:43 +0200)]
Atom.violated_conditionals: Use iuse.is_valid_flag instead of iuse.all
Zac Medico [Sat, 14 Aug 2010 05:02:09 +0000 (22:02 -0700)]
Add a SIGUSR1 handling to trigger pdb.set_trace().
Zac Medico [Sat, 14 Aug 2010 04:53:39 +0000 (21:53 -0700)]
Add back the POLLHUP handling for now since PipeReaderTestCase breaks
without it.
Zac Medico [Sat, 14 Aug 2010 04:29:54 +0000 (21:29 -0700)]
Stop handling POLLHUP events, since we're only polling for input and
POLLHUP is really intendend for purposes of output polling. Hopefully
this solves a problem with POLLHUP events causing premature
unregistration of event handlers (and subsequent hang in waitpid).
Zac Medico [Sat, 14 Aug 2010 04:05:10 +0000 (21:05 -0700)]
Define basestring for python3.
Sebastian Luther [Wed, 24 Mar 2010 07:22:58 +0000 (08:22 +0100)]
Implement use dependency defaults
Zac Medico [Sat, 14 Aug 2010 03:03:22 +0000 (20:03 -0700)]
Don't call exit after pkg_nofetch since that prevents the ebuild-ipc
callback from executing.
Zac Medico [Sat, 14 Aug 2010 02:07:23 +0000 (19:07 -0700)]
Filter PORTAGE_PYTHON in save_ebuild_env().
Zac Medico [Sat, 14 Aug 2010 02:01:14 +0000 (19:01 -0700)]
Merge branch 'master' of git+ssh://git.overlays.gentoo.org/proj/portage
Zac Medico [Sat, 14 Aug 2010 02:00:44 +0000 (19:00 -0700)]
Add a SIGUSR1 handler to trigger pdb.set_trace().
Arfrever Frehtes Taifersar Arahesis [Sat, 14 Aug 2010 01:11:41 +0000 (03:11 +0200)]
Use /usr/bin/python when PORTAGE_PYTHON variable is empty.
It avoids some errors during upgrade from older Portage versions.
Arfrever Frehtes Taifersar Arahesis [Sat, 14 Aug 2010 00:15:08 +0000 (02:15 +0200)]
Set PORTAGE_PYTHON in processes executed by portage.process._exec().
Arfrever Frehtes Taifersar Arahesis [Fri, 13 Aug 2010 22:45:51 +0000 (00:45 +0200)]
portage.os is apparently imported, so os doesn't need to be imported.
Arfrever Frehtes Taifersar Arahesis [Fri, 13 Aug 2010 22:41:28 +0000 (00:41 +0200)]
Add a script, which simplifies testing with multiple versions of Python.
Arfrever Frehtes Taifersar Arahesis [Fri, 13 Aug 2010 22:28:36 +0000 (00:28 +0200)]
Ensure that all Python processes use the same version of Python.
Zac Medico [Fri, 13 Aug 2010 19:49:16 +0000 (12:49 -0700)]
Setup EBUILD_MASTER_PID at the bottom, for scripts that source
ebuild.sh.
Zac Medico [Fri, 13 Aug 2010 19:33:48 +0000 (12:33 -0700)]
Handle KeyError due to stale events.
Zac Medico [Fri, 13 Aug 2010 19:24:12 +0000 (12:24 -0700)]
Set o-r on ipc fifos since the are sensitive to reading.
Zac Medico [Fri, 13 Aug 2010 19:14:06 +0000 (12:14 -0700)]
Bug #315615 - Use EbuildIpcDaemon to implement has_version and best_version.
This provides performance benefits and also avoids permissions issues with
FEATURES=userpriv.
Zac Medico [Fri, 13 Aug 2010 17:53:59 +0000 (10:53 -0700)]
Rename SubProcess._zombie() to _orphan_process_warn() and clarify
the eerror message.
Zac Medico [Fri, 13 Aug 2010 17:32:48 +0000 (10:32 -0700)]
Move EBUILD_MASTER_PID and associated SIGTERM trap into ebuild_main()
since it seems more reliable this way. This helps us avoid having
EbuildIpcDaemon need to send a kill signal (and triggering the
zombie message too). This is especially important for the die helper
which is called by other helpers for EAPI 4.
Zac Medico [Fri, 13 Aug 2010 16:37:15 +0000 (09:37 -0700)]
Disable the die() stack trace when called by the die helper.
Zac Medico [Fri, 13 Aug 2010 15:35:53 +0000 (08:35 -0700)]
Remove message about race conditions in die, solved by EbuildIpcDaemon.
Zac Medico [Fri, 13 Aug 2010 15:29:37 +0000 (08:29 -0700)]
Write eerror messages to the log file, and only to stdout when
appropriate.
Zac Medico [Fri, 13 Aug 2010 14:52:50 +0000 (07:52 -0700)]
Merge branch 'master' of git+ssh://git.overlays.gentoo.org/proj/portage
Arfrever Frehtes Taifersar Arahesis [Fri, 13 Aug 2010 14:52:54 +0000 (16:52 +0200)]
Add QA check for libtool libraries in Python site-packages directories.
Zac Medico [Fri, 13 Aug 2010 14:47:56 +0000 (07:47 -0700)]
Bug #278895 - After EbuildIpcDaemon identifies an ebuild process that
has left an orphan child process running in the background, generate
an eerror message about a 'zombie' process and note the pid.
Arfrever Frehtes Taifersar Arahesis [Fri, 13 Aug 2010 14:46:34 +0000 (16:46 +0200)]
Add QA check for static libraries in Python site-packages directories.
Arfrever Frehtes Taifersar Arahesis [Fri, 13 Aug 2010 14:28:22 +0000 (16:28 +0200)]
Remove files generated by testCompileModules.
Arfrever Frehtes Taifersar Arahesis [Fri, 13 Aug 2010 14:23:35 +0000 (16:23 +0200)]
Fix some comments.
Zac Medico [Fri, 13 Aug 2010 14:05:12 +0000 (07:05 -0700)]
Use EbuildIpcDaemon to replace the functionality of
EBUILD_EXIT_STATUS_FILE.
Zac Medico [Fri, 13 Aug 2010 14:03:43 +0000 (07:03 -0700)]
Use SpawnProcess instead of doebuild.spawn().
Zac Medico [Fri, 13 Aug 2010 13:31:59 +0000 (06:31 -0700)]
* Fix IndexError in PollScheduler._next_poll_event() by raising
StopIteration instead.
* Add an optional timeout parameter to PollScheduler._schedule_wait()
(this will be used in a later commit).
Zac Medico [Fri, 13 Aug 2010 06:58:22 +0000 (23:58 -0700)]
Call pickle.load() directly on the input pipe, and handle exceptions.
Zac Medico [Fri, 13 Aug 2010 06:11:53 +0000 (23:11 -0700)]
Refactor interaction between EbuildIpcDaemon and ExitCommand.
Zac Medico [Fri, 13 Aug 2010 05:33:56 +0000 (22:33 -0700)]
Clean up a bit.
Zac Medico [Fri, 13 Aug 2010 05:08:56 +0000 (22:08 -0700)]
Make IpcDaemonTestCase demonstrate an EbuildIpcDaemon based
replacement for EBUILD_EXIT_STATUS_FILE.
Zac Medico [Fri, 13 Aug 2010 03:46:53 +0000 (20:46 -0700)]
Split out an EbuildIpcDaemon class from FifoIpcDaemon.
Zac Medico [Fri, 13 Aug 2010 01:42:08 +0000 (18:42 -0700)]
Fix inverted logic in eapi_supports_prefix() call, which causes a
regression such that ED, EPREFIX, and EROOT where not set in EAPI 3
ebuild environments (just for portage-9999 users).
Zac Medico [Thu, 12 Aug 2010 18:39:31 +0000 (11:39 -0700)]
Make locks quiet since unintended locking messages displayed on
stdout could corrupt the intended output of this program.
Zac Medico [Thu, 12 Aug 2010 18:21:43 +0000 (11:21 -0700)]
Don't use unicode wrapper for mkfifo since it only allows string
arguments in python3.
Zac Medico [Thu, 12 Aug 2010 17:01:02 +0000 (10:01 -0700)]
Add some pieces of an IPC framework that will eventually allow ebuild
processes can to communicate with portage's main python process.
Here are a few possible uses:
1) Robust subshell/subprocess die support. This allows the ebuild
environment to reliably die without having to rely on signal IPC.
2) Delegation of portageq calls to the main python process, eliminating
performance and userpriv permission issues.
3) Reliable ebuild termination in cases when the ebuild has accidentally
left orphan processes running in the backgraound (as in bug 278895).
Sebastian Luther [Thu, 12 Aug 2010 15:31:43 +0000 (17:31 +0200)]
Tests: ResolverPlayground: more debug stuff
Zac Medico [Thu, 12 Aug 2010 13:51:11 +0000 (06:51 -0700)]
Avoid unnecessary sys.hexversion conditional.
Zac Medico [Thu, 12 Aug 2010 12:56:22 +0000 (05:56 -0700)]
Factor EBUILD_EXIT_STATUS_FILE code out of AbstractEbuildProcess
subclasses and into AbstractEbuildProcess itself.
Sebastian Luther [Thu, 12 Aug 2010 12:00:13 +0000 (14:00 +0200)]
Tests: ResolverPlayground: add debug option to not supress depgraph output
Useful for debugging test cases.
Sebastian Luther [Thu, 12 Aug 2010 11:55:55 +0000 (13:55 +0200)]
Tests: ResolverPlayground: create world file
Zac Medico [Thu, 12 Aug 2010 11:21:05 +0000 (04:21 -0700)]
Consolidate EBUILD_EXIT_STATUS_FILE handling in doebuild.spawn()
and subclasses of AbstractEbuildProcess.
Zac Medico [Thu, 12 Aug 2010 10:56:20 +0000 (03:56 -0700)]
Fix lazyimport() to handle partially imported modules by creating
proxies, instead of raising ImportError.
Sebastian Luther [Thu, 12 Aug 2010 10:32:02 +0000 (12:32 +0200)]
autounmask: Print use flag that trigger a given dep in comments
Sebastian Luther [Thu, 12 Aug 2010 10:31:23 +0000 (12:31 +0200)]
Tests: more resolver/test_autounmask tests
Sebastian Luther [Thu, 12 Aug 2010 10:30:20 +0000 (12:30 +0200)]
portage.dep.extract_affecting_use: Don't raise if atom is not in dep string
Sebastian Luther [Thu, 12 Aug 2010 10:29:05 +0000 (12:29 +0200)]
Tests: Fix typo bug ResolverPlayground
Sebastian Luther [Thu, 12 Aug 2010 08:59:33 +0000 (10:59 +0200)]
Add portage.dep.extract_affecting_use()
Zac Medico [Thu, 12 Aug 2010 08:47:04 +0000 (01:47 -0700)]
Fix faulty $? handling in *into functions (from previous commit).
Dror Levin [Wed, 26 May 2010 20:23:38 +0000 (23:23 +0300)]
Make utilities die on failure in EAPI 4, bug 273651
Zac Medico [Thu, 12 Aug 2010 08:29:38 +0000 (01:29 -0700)]
Add copyright header.
Zac Medico [Thu, 12 Aug 2010 08:19:41 +0000 (01:19 -0700)]
Add missing __init__.py
Sebastian Luther [Wed, 11 Aug 2010 11:24:48 +0000 (13:24 +0200)]
Tests: More slot_collision_handler tests
Sebastian Luther [Wed, 11 Aug 2010 11:16:23 +0000 (13:16 +0200)]
Fix slot_collision_handler tests
Sebastian Luther [Mon, 9 Aug 2010 10:06:31 +0000 (12:06 +0200)]
Tests: add resolver/test_slot_collisions
Sebastian Luther [Mon, 9 Aug 2010 10:05:54 +0000 (12:05 +0200)]
Tests: resolver/ResolverPlayground: Create a proper profile
Sebastian Luther [Mon, 9 Aug 2010 07:25:35 +0000 (09:25 +0200)]
_emerge.depgraph: use writemsg() instead of print() (to silence tests)
Sebastian Luther [Mon, 9 Aug 2010 06:03:00 +0000 (08:03 +0200)]
Tests: Fix bug in resolver/ResolverPlayground
Sebastian Luther [Mon, 9 Aug 2010 05:54:45 +0000 (07:54 +0200)]
Tests: resolver/test_slot_collisions: Check for slot_collision_solutions
Sebastian Luther [Tue, 15 Jun 2010 21:15:30 +0000 (23:15 +0200)]
slot_collision_handler: Add more documentation
Sebastian Luther [Tue, 8 Jun 2010 10:12:24 +0000 (12:12 +0200)]
slot_collision_handler: Fix function names broken by import changes
Sebastian Luther [Mon, 7 Jun 2010 21:01:02 +0000 (23:01 +0200)]
slot_collision_handler: Minor formatting changes
Sebastian Luther [Mon, 7 Jun 2010 20:59:57 +0000 (22:59 +0200)]
slot_collision_handler: Pass noiselevel=-1 to writemsg for debug output
Sebastian Luther [Mon, 7 Jun 2010 20:54:12 +0000 (22:54 +0200)]
Remove unused import
Sebastian Luther [Mon, 7 Jun 2010 18:11:45 +0000 (20:11 +0200)]
slot_collision_handler: Return a string instead of priting the messages to screen.