Skip to content

Latest commit

 

History

History
815 lines (552 loc) · 23.5 KB

CHANGELOG.rst

File metadata and controls

815 lines (552 loc) · 23.5 KB

Changelog

Contents

  • Fix docs generation.
  • Drop support for Python 3.5 and DC/OS 1.9 - 1.12. These versions may continue to work, but will no longer be tested.
  • Drop support for CoreOS on AWS
  • Use blocking read to ensure final data is read from subprocess.
  • Updated google-api-python-client to v1.7.12.
  • Added support for CentOS 8 and Flatcar when using Docker.
  • Changed the default version of dcos-vagrant-box to 0.10.
  • Updated dependencies.
  • Drop support for RHEL in minidcos aws.
  • Update vendored dcos-test-utils dependency.
  • Bump dcos-test-utils dependency.
  • Fix issue which prevented CoreOS nodes starting on Docker.
  • Renamed Cluster.run_integration_tests's test_host parameter to node.
  • Renamed Cluster.run_integration_tests's pytest_command parameter to args.
  • Renamed Cluster.run_integration_tests to Cluster.run_with_test_environment.
  • Split Cluster and Node upgrade and install_dcos functions into *_dcos_from_[path|url] functions.
  • Enable larger log sizes and lower memory uses by moving Docker backend logs to the host disk.
  • Add minidcos aws destroy and minidcos aws destroy-list commands.
  • Fix error "No module named 'keyring.util.escape'".
  • Added Cluster.upgrade_dcos and minidcos upgrade commands.
  • Replaced Cluster.install_dcos_from_url and Cluster.install_dcos_from_path with Cluster.install_dcos which takes a URL or Path.
  • Replaced Node.install_dcos_from_url and Node.install_dcos_from_path with Node.install_dcos which takes a URL or Path.
  • Fix minidcos inspect commands for legacy versions of DC/OS.
  • Add options to enable or disable spinner animations in minidcos.
  • Get DC/OS build information from a Node object after installation.
  • Added option to minidcos aws create and minidcos aws provision to choose the AWS instance type.
  • Changed the default version of Docker installed on minidcos docker clusters to 18.06.3-ce.
  • Added Node.upgrade_dcos_from_path.
  • Added minidcos docker upgrade.
  • Added options to choose the amount of memory given to each VM.
  • Fixed a bug which prevented minidcos vagrant from working when a VM existed with a space in the name.
  • Fixed a bug which prevented minidcos vagrant from working in some situations when the $HOME environment variable is not set.
  • Add a minidcos docker doctor check which fails when using Boot2Docker.
  • Fix issue with minidcos vagrant which prevented node access via SSH.
  • Change minidcos default credentials for DC/OS Enterprise clusters from admin/admin to bootstrapuser/deleteme.
  • Download a file or directory from a Node.
  • Improve efficiency of installing DC/OS with create on minidcos docker and minidcos aws.
  • Allow the use of a MINIDCOS_NODE_DOCKER_VERSION environment variable to set the version of Docker inside minidcos docker nodes.
  • Remove use of select which is not supported on Windows.
  • minidcos docker clean will no longer clean up containers which are started from now on by the tooling to create a custom macOS network.
  • The wait_for_dcos_oss and wait_for_dcos_ee methods no longer log output of node poststart check command run.
  • The Node.run method logs the command that is going to execute with debug level if output is configured to LOG_AND_CAPTURE.
  • The Node.run method no longer logs stderr when Output.CAPTURE is used.
  • The Node.run method no longer merges stderr into stdout when Output.LOG_AND_CAPTURE is used.
  • The library no longer configures logger handler. Applications using dcos_e2e library that were relying on logging being printed to stdout should configure logging on its own.
  • Add new commands to minidcos vagrant and minidcos aws to provision a bare cluster (provision) and install DC/OS on a bare cluster (install).
  • Improve the spinner while waiting for minidcos commands.
  • Add send-file commands to minidcos subcommands.
  • Remove --env option on minidcos docker inspect.
  • Custom backends must now specify the base config in the ClusterBackend rather than the ClusterManager.
  • Add new commands to minidcos docker to provision a bare cluster (provision) and install DC/OS on a bare cluster (install).
  • Add minidcos vagrant clean command to clean up left over VMs.
  • Allow multiple --node options on run commands to run a command on multiple nodes.
  • minidcos vagrant list will now not show clusters with aborted VMs. A VM is aborted for example if the host is shut down.
  • Make various minidcos commands faster by using caching.
  • Remove warnings about YAML when running minidcos vagrant.
  • Change names of install functions for custom backends to remove _with_bootstrap_node.
  • Allow login after minidcos docker wait on DC/OS OSS 1.13.
  • Mount /sys/fs/cgroup into Docker agents by default.
  • Add options to the CLI and library to disable mounting /sys/fs/cgroup.
  • Stop mounting /sys/fs/cgroup into Docker agents.
  • Add more minidcos docker doctor checks.
  • Fix issue where "RuntimeError: cannot join current thread" was shown.
  • Backwards incompatible change: Move ClusterBackend and ClusterManager to dcos_e2e.base_classes.
  • Limit UUID in the cluster ID to 5 characters to avoid problems with Docker.
  • Ship type hints for other packages to use.
  • Allow -h instead of --help on all CLI commands.
  • Allow multiple --sync-dir options to be given to run commands.
  • Rename build_artifact and related variables to "installer".
  • If syncing a DC/OS OSS repository to a DC/OS Enterprise cluster, only Open Source tests are synced.
  • Backwards incompatible change: Changed CLI commands from dcos-docker to minidcos docker and alike.
  • Add a dcos-docker doctor check for systemd.
  • Add a progress bar for doctor commands.
  • Log subprocess output unicode characters where possible.
  • Backwards incompatible change: Change --no-test-env to --test-env on run commands, with the opposite default.
  • Fix an issue which caused incompatible version errors between keyring and SecretStore dependencies.
  • Add dcos-docker create-loopback-sidecar and dcos-docker destroy-loopback-sidecar commands to provide unformatted block devices to DC/OS.
  • Add dcos-docker clean command to clean left over artifacts.
  • Backwards incompatible change: Changed names of VPN containers on macOS.
  • Fix an issue which stopped the SSH transport from working on CLIs.
  • Remove log_output_live parameters on various functions in favor of new output options.
  • Node.__init__'s ssh_key_path parameter now expects a path to an SSH key file with specific permissions.
    See the documentation for this class for details.
  • The docker-exec transport uses interactive mode only when running in a terminal.
  • Show full path on download-artifact downloads.
  • Default to downloading to the current directory for download-artifact downloads.
  • Use a TTY on CLI run commands only if Stdin is a TTY.
  • Fix issues which stopped pre-built Linux binaries from working.
  • wait_for_dcos_oss and wait_for_dcos_ee now raise a custom DCOSTimeoutError if DC/OS has not started within one hour.
  • The --variant option is now required for the dcos-aws CLI.
  • Added the ability to install on Linux from a pre-built binary.
  • Add the ability to do a release to a fork.
  • Fix using macOS with no custom network.
  • Support for CoreOS on the AWS backend.
  • Fix an issue which prevented the Vagrant backend from working.
  • Improve diagnostics when creating a Docker-backed cluster with no running Docker daemon.
  • Add instructions for uninstalling DC/OS E2E.
  • Pin msrestazure pip dependency to specific version to avoid dependency conflict.
  • Add a dcos-docker doctor check that relevant Docker images can be built.
  • Add Red Hat Enterprise Linux 7.4 support to the AWS backend.
  • Fix bug which meant that a user could not log in after dcos-docker wait on DC/OS Open Source clusters.
  • Backwards incompatible change: Remove files_to_copy_to_installer from Cluster.__init__ and add files_to_copy_to_genconf_dir as an argument to Cluster.install_dcos_from_path as well as Cluster.install_dcos_from_url.
  • Add files_to_copy_to_genconf_dir as an argument to Node.install_dcos_from_path and Node.install_dcos_from_url.
  • Add the capability of sending a directory to a Node via Node.send_file.
  • Add ip_detect_path to the each ClusterBackend as a property and to each install DC/OS function as a parameter.
  • Add an initial dcos-aws CLI.
  • Add dcos-docker download-artifact and dcos-vagrant download-artifact.
  • Add verbose option to multiple commands.
  • Add virtualbox_description parameter to the Vagrant backend.
  • Change the default transport for the Docker backend to DOCKER_EXEC.
  • Add a --one-master-host-port-map option to dcos-docker create.
  • Execute node-poststart checks in Cluster.wait_for_dcos and Cluster.wait_for_dcos_ee.
  • Add dcos-vagrant doctor checks.
  • Add a --network option to the dcos-docker CLI.
  • Add a dcos-vagrant CLI.
  • Renamed Homebrew formula. To upgrade from a previous version, follow Homebrew's linking instructions after upgrade instructions.
  • Add a Vagrant backend.
  • Add a aws_instance_type parameter to the AWS backend.
  • Compare Node objects based on the public_ip_address and private_ip_address.
  • Add a network parameter to the Docker backend.
  • Add platform-independent DC/OS installation method from Path and URL on Node.
  • Add dcos-docker doctor check for a version conflict between systemd and Docker.
  • Allow installing DC/OS by a URL on the Docker backend, and a cluster from_nodes.
  • Add Cluster.remove_node.
  • Add Ubuntu support to the Docker backend.
  • Add aws_key_pair parameter to the AWS backend.
  • Fix Linuxbrew installation on Ubuntu.
  • Add a --wait flag to dcos-docker create to also wait for the cluster.
  • dcos-docker create now creates clusters with the --cluster-id "default" by default.
  • Change Node.default_ssh_user to Node.default_user.
  • Add a docker exec transport to Node operations.
  • Add a --transport options to multiple dcos-docker commands.
  • Do not pin setuptools to an exact version.
  • Add --env option to dcos-docker run.
  • Make xfs_info available on nodes, meaning that preflight checks can be run on nodes with XFS.
  • Fix dcos-docker doctor for cases where df produces very long results.
  • Show a formatted error rather than a traceback if Docker cannot be connected to.
  • Custom backends' must now implement a base_config method.
  • Custom backends' installation methods must now take dcos_config rather than extra_config.
  • Cluster.install_dcos_from_url and Cluster.install_dcos_from_path now take dcos_config rather than extra_config.
  • Add a --variant option to dcos-docker create to speed up cluster creation.
  • Add a test_host parameter to Cluster.run_integration_tests.
  • Add the ability to specify a node to use for dcos-docker run.
  • Show IP address in dcos-docker inspect.
  • Expose the SSH key location in dcos-docker inspect.
  • Make network created by setup-mac-network now survives restarts.
  • Previously not all volumes were destroyed when destroying a cluster from the CLI or with the Docker backend. This has been resolved. To remove dangling volumes from previous versions, use docker volume prune.
  • Backwards incompatible change: mount parameters to Docker.__init__ now take a list of docker.types.Mounts.
  • Docker version 17.06 or later is now required for the CLI and for the Docker backend.
  • Added dcos-docker destroy-mac-network command.
  • Added a --force parameter to dcos-docker setup-mac-network to override files and containers.
  • Added dcos-docker setup-mac-network command.
  • Logs from dependencies are no longer emitted.
  • The dcos-docker CLI now gives more feedback to let you know that things are happening.
  • The AWS backend now supports DC/OS 1.9.
  • The Docker backend now supports having custom mounts which apply to all nodes.
  • Add custom-volume parameter (and similar for each node type) to dcos-docker create.
  • Add an AWS backend to the library.
  • Add ability to control which labels are added to particular node types on the Docker backend.
  • Add support for Ubuntu on the Docker backend.
  • Add a new dcos-docker doctor check for suitable sed for DC/OS 1.9.
  • Support cluster.run_integration_tests on DC/OS 1.9.
  • Add support for DC/OS 1.9 on Linux hosts.
  • dcos-docker doctor returns a status code of 1 if there are any errors.
  • Add a new dcos-docker doctor check for free space in the Docker root directory.
  • Add a dcos-docker doctor check that a supported storage driver is available.
  • Fix error with using Docker version v17.12.1-ce inside Docker nodes.
  • Fix race condition between installing DC/OS and SSH starting.
  • Remove support for Ubuntu on the Docker backend.
  • Fix public agents on DC/OS 1.10.
  • Remove options to use Fedora and Debian in the Docker backend nodes.
  • Fix the Ubuntu distribution on the Docker backend.
  • Add support for Docker 17.12.1-ce on nodes in the Docker backend.
  • Exceptions in create in the CLI point towards the doctor command.
  • Removed a race condition in the doctor command.
  • dcos-docker run now exits with the return code of the command run.
  • dcos-docker destroy-list is a new command and dcos-docker destroy now adheres to the common semantics of the CLI.
  • Add Vagrantfile to run DC/OS E2E in a virtual machine.
  • Add instructions for running DC/OS E2E on Windows.
  • Allow relative paths for the build artifact.
  • Backwards incompatible change: Move default_ssh_user parameter from Cluster to Node. The default_ssh_user is now used for Node.run, Node.popen and Node.send_file if user is not supplied.
  • Add linux_distribution parameter to the Docker backend.
  • Add support for CoreOS in the Docker backend.
  • Add docker_version parameter to the Docker backend.
  • The fallback Docker storage driver for the Docker backend is now aufs.
  • Add storage_driver parameter to the Docker backend.
  • Add docker_container_labels parameter to the Docker backend.
  • Logs are now less cluttered with escape characters.
  • Documentation is now on Read The Docs.
  • Add a Command Line Interface.
  • Vendor dcos_test_utils so --process-dependency-links is not needed.
  • Backwards incompatible change: Cluter's files_to_copy_to_installer argument is now a List of Tuples rather than a Dict.
  • Add a tty option to Node.run and Cluster.run_integration_tests.
  • Backwards incompatible change: Change the default behavior of Node.run and Node.popen to quote arguments, unless a new shell parameter is True. These methods now behave similarly to subprocess.run.
  • Add custom string representation for Node object.
  • Bump dcos-test-utils for better diagnostics reports.
  • Expose the public_ip_address of the SSH connection and the private_ip_address of its DC/OS component on Node objects.
  • Bump dcos-test-utils for better diagnostics reports.
  • Replace the extended wait_for_dcos_ee timeout with a preceding dcos-diagnostics check.
  • Extend wait_for_dcos_ee timeout for waiting until the DC/OS CA cert can be fetched.
  • Backwards incompatible change: Introduce separate wait_for_dcos_oss and wait_for_dcos_ee methods. Both methods improve the boot process waiting time for the corresponding DC/OS version.
  • Backwards incompatible change: run_integration_tests now requires users to call wait_for_dcos_oss or wait_for_dcos_ee beforehand.
  • Remove ExistingCluster backend and replaced it with simpler Cluster.from_nodes method.
  • Simplified the default configuration for the Docker backend. Notably this no longer contains a default superuser_username or superuser_password_hash.
  • Support custom_agent_mounts and custom_public_agent_mounts on the Docker backend.
  • Remove destroy_on_error and destroy_on_success from Cluster. Instead, avoid using Cluster as a context manager to keep the cluster alive.
  • Backwards incompatible change: Rename DCOS_Docker backend to Docker backend.
  • Backwards incompatible change: Replace generate_config_path with build_artifact that can either be a Path or a HTTP(S) URL string. This allows for supporting installation methods that require build artifacts to be downloaded from a HTTP server.
  • Backwards incompatible change: Remove run_as_root. Instead require a default_ssh_user for backends to run commands over SSH on any cluster Node created with this backend.
  • Backwards incompatible change: Split the DC/OS installation from the ClusterManager __init__ procedure. This allows for installing DC/OS after Cluster creation, and therefore enables decoupling of transferring files ahead of the installation process.
  • Backwards incompatible change: Explicit distinction of installation methods by providing separate methods for install_dcos_from_path and install_dcos_from_url instead of inspecting the type of build_artifact.
  • Backwards incompatible change: log_output_live is no longer an attribute of the Cluster class. It may now be passed separately as a parameter for each output-generating operation.
  • Added Node.send_file to allow files to be copied to nodes.
  • Added custom_master_mounts to the DC/OS Docker backend.
  • Backwards incompatible change: Removed files_to_copy_to_masters. Instead, use custom_master_mounts or Node.send_file.
  • Added Apache2 license.
  • Repository moved to https://github.com/dcos/dcos-e2e.
  • Added run, which is similar to run_as_root but takes a user argument.
  • Added popen, which can be used for running commands asynchronously.
  • Fix bug where Node reprs were put into environment variables rather than IP addresses. This prevented some integration tests from working.
  • Fixed issue which prevented files_to_copy_to_installer from working.
  • The Enterprise DC/OS integration tests now require environment variables describing the IP addresses of the cluster. Now passes these environment variables.
  • Wait for 5 minutes after diagnostics check.
  • Account for the name of 3dt having changed to dcos-diagnostics.
  • Support platforms where $HOME is set as /root.
  • Cluster.wait_for_dcos now waits for CA cert to be available.
  • Add ability to specify a workspace.
  • Fixed issue with DC/OS Docker files not existing in the repository.
  • Vendor DC/OS Docker so a path is not needed.
  • If log_output_live is set to True for a Cluster, logs are shown in wait_for_dcos.
  • More storage efficient.
  • Removed need to tell Cluster whether a cluster is an enterprise cluster.
  • Removed need to tell Cluster the superuser_password.
  • Added ability to set environment variables on remote nodes when running commands.
  • Initial release.