Commit Graph

2236 Commits

Author SHA1 Message Date
David Wilson 6e9f8e829e issue #429: teach sudo about every know i18n password string. 2019-01-29 06:01:48 +00:00
David Wilson 960e505f07 issue #429: install i18n-related bits in test images. 2019-01-29 06:01:48 +00:00
David Wilson ec789513dc ssh: tidy up logs and stream names. 2019-01-29 06:01:48 +00:00
David Wilson eb93f82d05 tests: ensure file is closed in connection_test. 2019-01-29 06:01:48 +00:00
David Wilson 73979043ad gcloud: small updates 2019-01-29 06:01:48 +00:00
David Wilson 59068ca955 tests: give ansible/gcloud/ its own requirements file. 2019-01-29 06:01:48 +00:00
David Wilson fba06b0bde Merge remote-tracking branch 'origin/issue499'
* origin/issue499:
  issue #499: another totally moronic implementation difference
  issue #499: disable new test on vanilla.
  docs: update Changelog; closes #499.
  issue #499: respect C.BECOME_ALLOW_SAME_USER.
2019-01-29 04:36:11 +00:00
David Wilson 9df314f9c5 issue #499: another totally moronic implementation difference 2019-01-29 03:55:18 +00:00
David Wilson 53794469a0 issue #499: disable new test on vanilla. 2019-01-29 03:26:21 +00:00
David Wilson 60e9596e7d docs: update Changelog; closes #499. 2019-01-29 02:54:18 +00:00
David Wilson a1121c5a84 issue #499: respect C.BECOME_ALLOW_SAME_USER. 2019-01-29 02:53:21 +00:00
David Wilson 16a2de65c4 issue #493: another Py3.x fix. 2019-01-27 20:11:24 +00:00
David Wilson 2a70b3d5f4 issue #493: Py3.x fix. 2019-01-27 20:01:12 +00:00
David Wilson 9f7db66f67 tox: add py37 target. 2019-01-27 19:54:07 +00:00
David Wilson 3158c4ae9d docs: update Changelog; closes #493. 2019-01-27 19:53:38 +00:00
David Wilson bc84d1e950 issue #493: less CPU-intensive cookie format. 2019-01-27 19:41:55 +00:00
David Wilson 14d393765b issue #488: 2.4-compatible syntax in unix.py. 2019-01-27 19:38:17 +00:00
David Wilson b254051416 ansible: add test to ensure UNIX socket is cleaned on exit; closes #488. 2019-01-27 19:29:16 +00:00
David Wilson 628e8f4466 Bump PyYaML to a 3.7-compatible version. 2019-01-27 19:23:44 +00:00
David Wilson be6ab52fe1 issue #488: fix shutdown damage caused in 6ca2677de5
os._exit() subverted calm shutdown, meaning unix.Listener never had a
chance to cleanup its socket.

Move unix.Listener socket cleanup into its class so it is automatic
during shutdown, rather than cutpasted for each consumer.

Disable the watcher thread in the MuxProcess, it is useless.

Add .sock extension to /tmp/mitogen_unix_*, so we can write a test.
2019-01-27 19:21:50 +00:00
David Wilson 104fa463af Merge remote-tracking branch 'origin/issue479'
* origin/issue479:
  issue #490: log mitogen.unix server-side accept.
  issue #490: have Side._on_fork() empty _fork_refs
  issue #490: prevent double close() destroying unrelated Connection.
  docs: update Changelog; closes #479.
  issue #479: ModuleFinder special case for __main__ on Py3.x.
2019-01-27 19:09:14 +00:00
David Wilson b370076689 issue #490: log mitogen.unix server-side accept. 2019-01-27 18:48:19 +00:00
David Wilson 7dae88f0f5 issue #490: have Side._on_fork() empty _fork_refs
This is mostly to avoid ugly debugging that depends on the state of GC.
Discard sides from _fork_refs after they have been closed.
2019-01-27 18:47:28 +00:00
David Wilson 38a553d42d issue #490: prevent double close() destroying unrelated Connection. 2019-01-27 18:46:03 +00:00
David Wilson bf676aacfe docs: update Changelog; closes #479. 2019-01-27 16:20:55 +00:00
David Wilson 3435f24e8d issue #479: ModuleFinder special case for __main__ on Py3.x. 2019-01-27 16:17:56 +00:00
David Wilson 245dd9e166 Merge remote-tracking branch 'origin/dmw'
* origin/dmw: (135 commits)
  tests: just disable the test.
  tests: hopefully fix this dumb test for the final time
  docs: update Changelog; closes #477.
  issue #477: use MITOGEN_INVENTORY_FILE everywhere.
  issue #477: hacksmash weird 2.3 inventory_file var issue.
  issue #477: travis.yml typo.
  issue #477: fix sudo_args selection.
  issue #477: one more conditional test.
  issue #477: enable Ansible 2.3.3 CI.
  issue #477: some more conditional tests.
  docs: update Changelog.
  issue #477 / ansible: avoid a race in async job startup.
  issue #477: use assert_equal for nicer debug.
  issue #477: fix source of become_flags on 2.3.
  issue #477: add Connection.homedir test.
  core: docstring tidyups.
  core: ensure early debug messages are logged correctly.
  core: log disconnection reason.
  issue #477: target.file_exists() wrapper.
  issue #477: introduce subprocess isolation.
  ansible: docstring fixes.
  issue #477: paper over Ansible 2.3 flag handling difference
  issue #477: update forking_correct_parent for subprocess isolation
  issue #477: shlex.split() in 2.4 required bytes input.
  issue #477: get rid of perl JSON module requirement.
  issue #477: Ansible 2.3 did not support gather_facts min subset.
  issue #477: CentOS 5 image requires perl installed too.
  issue #477: missing stub-su.py from 137f5fa6c5
  issue #477: 2.4-compatible syntax.
  issue #477: clearing glibc caches is not possible on Py2.4.
  parent: --with-pydebug bootstrap could fail due to corrupted stream
  issue #477: install simplejson for vanilla tests.
  docs: update Changelog.
  ansible: synchronize module needs '.docker_cmd' attr for Docker plugin.
  issue #477: add basic su_test and Py2.4 polyfill.
  issue #477: import updated Python build scripts
  ci: don't use the TTY->pipe hack except on Travis where it's needed.
  WIP first run of py24 CI
  issue #477: initial Python 2.4.6 build for CI.
  issue #477: enable git-lfs for tests/data/*.tar.bz2.
  issue #477: import build script for Python 2.4.6.
  issue #477: add mitogen_py24 CI test type.
  issue #477: disable Django parts of module_finder_test on 2.4.
  issue #477: clean up globals after unix_test.
  issue #477: remove unused pytest bits from importer_test.
  issue #477: remove fork use from unix_test.
  parent: don't kill child when profiling=True
  issue #485: import new throuhgput bench
  issue #477: more fork removal
  issue #477: Py2.4 startswith() did not support tuples.
  issue #477: util/fakessh/two_three_compat fixes.
  issue #477: call_function_test fixes for 2.4.
  issue #477: promote setup_gil() to mitogen.utils
  issue #477: fix lxc_test any polyfill import.
  issue #477: stop using fork in responder_test.
  issue #477: stop using fork in service_test.
  issue #477: Python<2.5 ioctl() request parameter was signed.
  issue #477: stop using fork() in parent_test, compatible enumerate().
  issue #477: Popen.terminate() polyfill for Py2.4.
  issue #477: stop using .fork() in router_test, one small 2.4 fix.
  issue #477: document master.Router.max_message_size.
  issue #477: old Py zlib did not include extended exception text.
  issue #477: stop using router.fork() in receiver_test
  issue #477: any() polyfill for lxc_test.
  issue #477: replace type(e) -> __class__ for an exception
  issue #477: old Mock does not throw side_effect exceptions from a list
  issue #477: 2.4 stat() returned int timestamps not float.
  issue #477: set().union(a, b, ..) unsupported on Py2.4.
  issue #477: Logger.log(extra=) unsupported on Py2.4.
  issue #477: fix another Threading.getName() call.
  issue #477: %f date format requires Py2.6 or newer.
  issue #477: make mitogen.fork unsupported on Py<2.6.
  issue #477: Py2.4 dep scanner bytecode difference
  Drop 'alpha' trove classifier
  issue #477: fix another str/bytes mixup.
  issue #477: blacklist 'thread' module to avoid roundtrip on 2.x->3.x
  issue #477: fix 3.x failure in new target.set_file_mode() function.
  issue #477: fix 3.x failure in new target.set_file_mode() function.
  issue #477: fix 2 runner tests on Ansible 2.7.
  issue #477: fix 3.x test regressions.
  issue #477: fix new KwargsTest on Python 3.x.
  issue #477: ModuleFinder now returns Unicode module names.
  issue #477: Python3 does not have Pickler.dispatch.
  issue #477: ModuleFinder test fixes.
  issue #477: Ansible 2.3 compatible regression/all.yml.
  issue #477: Ansible 2.3 requires placeholder module for assert_equals
  issue #477: build a CentOS 5/Py2.4 container + playbook compat fixes.
  issue #477: use PY24 constant rather than explicit test.
  issue #477: backport mitogen.master to Python 2.4.
  issue #477: parent: make iter_read() log disconnect reason.
  issue #477: backport ansible_mitogen.runner to 2.4.
  issue #477: backport various test modules to Python 2.4.
  issue #477: backport ansible_mitogen/target.py to Python2.4
  issue #477: add all() polyfill to custom_python_detect_environmnet
  issue #477: polyfill partition() use in mitogen.parent.
  issue #477: polyfill partition() use in mitogen.service.
  issue #477: polyfill partition() use in mitogen.ssh.
  issue #477: vendorize the last 2.4-compatible simplejson
  issue #477: _update_linecache() must append newlines.
  issue #415, #477: Poller must handle POLLHUP too.
  ...
2019-01-27 06:57:45 +00:00
David Wilson a7da1b048b tests: just disable the test. 2019-01-27 06:37:06 +00:00
David Wilson cdb1434809 tests: hopefully fix this dumb test for the final time 2019-01-27 06:21:14 +00:00
David Wilson ac4e61e19e docs: update Changelog; closes #477. 2019-01-27 06:12:54 +00:00
David Wilson a67cc85bdb issue #477: use MITOGEN_INVENTORY_FILE everywhere. 2019-01-27 05:45:24 +00:00
David Wilson ea23d7fd54 issue #477: hacksmash weird 2.3 inventory_file var issue. 2019-01-27 05:31:26 +00:00
David Wilson ee44d98f13 issue #477: travis.yml typo.
We don't care if 2.3 can talk to newer systems, just CentOS 5/Py2.4.
2019-01-27 05:27:05 +00:00
David Wilson e7fe95af88 issue #477: fix sudo_args selection. 2019-01-27 05:07:36 +00:00
David Wilson 9aff8edf50 issue #477: one more conditional test. 2019-01-27 04:44:50 +00:00
David Wilson 59e5276af3 issue #477: enable Ansible 2.3.3 CI. 2019-01-27 04:44:24 +00:00
David Wilson e133b8dbb1 issue #477: some more conditional tests. 2019-01-27 04:43:12 +00:00
David Wilson bb9bb593e4 docs: update Changelog. 2019-01-27 04:31:59 +00:00
David Wilson 599da0689a issue #477 / ansible: avoid a race in async job startup.
Ansible 2.3/Python 2.4 work revealed there is no guarantee a slow target
will have written the initial job status file out before a fast
controller makes an initial check for it. Therefore, provide AsyncRunner
with a sender it should send a message to when the initial job file has
been written.

As a bonus, also catch and report exceptions happening early in
AsyncRunner, rather than leaving them to end up in -vvv output.
2019-01-27 04:27:41 +00:00
David Wilson 4095358ea4 Merge commit '5bd6bd0' into envtest
* commit '5bd6bd0':
  parent: don't send messages on streams that no longer exist; closes #480
2019-01-27 03:58:05 +00:00
David Wilson c61498202e issue #477: use assert_equal for nicer debug. 2019-01-27 03:50:41 +00:00
David Wilson 0175052099 issue #477: fix source of become_flags on 2.3. 2019-01-27 03:49:01 +00:00
David Wilson 5e4066bb64 issue #477: add Connection.homedir test. 2019-01-27 03:30:30 +00:00
David Wilson 2b234936b8 core: docstring tidyups. 2019-01-27 03:06:05 +00:00
David Wilson f17fb91993 core: ensure early debug messages are logged correctly.
The magical _v and _vv were being set too late. Drag _setup_logging()
out of the Router constructor and call it at the right moment during
bootstrap.
2019-01-27 03:05:11 +00:00
David Wilson 8a931e79b0 core: log disconnection reason. 2019-01-27 03:04:35 +00:00
David Wilson 97f3cfe4f4 issue #477: target.file_exists() wrapper.
os.path.exists physical module name varies across major Python versions.
2019-01-27 03:03:47 +00:00
David Wilson 8f5b65f7ec issue #477: introduce subprocess isolation.
Since Python 2.4 fork is so defective, we must use subprocesses for
mitogen_task_isolation=fork. This has plenty of upside, since the long
term goal is to dump forking altogether. This allows a gentle
introduction of its replacement.
2019-01-27 03:01:42 +00:00
David Wilson b9924683ac ansible: docstring fixes. 2019-01-27 03:00:46 +00:00
David Wilson 8385c38cff issue #477: paper over Ansible 2.3 flag handling difference 2019-01-27 02:30:59 +00:00