summaryrefslogtreecommitdiff
path: root/docsite/rst/roadmap/ROADMAP_2_3.rst
blob: 27dd11b0e645b66918e8981ded6359b873679b04 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
****************
Ansible by Red Hat,  Core 2.3
****************
**********************
Target: February/April 2017
**********************

**General Comments byt the Core Team:**  The 2.3 Ansible Core is just a little different than the past two major releases we've done.  In addition to feature work, we're using part of the time for this release to reduce some of our backlog in other areas than pure development.
  - *Administrivia:* 
    - Clean up our github repos and move to one repo so that contributions, tickets, submissions, etc are centralized and easier for both the community and the Core Team to manage.
  - Move to a Metadata based system for modules.  This has been discussed here: https://github.com/ansible/proposals/blob/master/modules-management.md
  - Documentation: We're aware that Docs have issues.  Scott Butler, aka Dharmabumstead will be leading the charge on how he and we as a community can clean them up.
  - *Backlog, Stability, Hardening:* We're spending some of the cycles for 2.3 trying to reduce our ticket/PR backlog, and clean up some particular areas of the project that the community has expressed particular frustrations about.
  - *Python 3:* The community and Toshio have done TONS of work getting Python 3 working.  Still more to go...
  - *Features:* We still have some cool stuff coming.  Check it out below.  For people on the Networking side of the world, the Persistent Connection Manager will be a *huge* feature and performance gain.

- **Repo Merge**

  - Script that a submitter can run to migrate their PR
  - Script that a committer can run to fork a PR and then merge to ansible/ansible
  - Move all the issues (remove old ones that can be removed)
  - Enhance ansibullbot to accommodate the changes (jctanner)
  
- **Metadata**

  - Add metadata to the modules we ship
  - Write code to use metadata in docs
  - If needed for python2/3 write code to use metadata in module_common or pluginloader
  
- **Documentation**
  
  - Update developing_modules
    - Dharmabumstead to set up rst skeleton for module_utils docs.
  - Plugin development docs
  - Speed up “make webdocs” https://github.com/ansible/ansible/issues/17406 
  - Revamp Release Notes: Consider Reno https://github.com/ansible/community/issues/61 

- **Windows platform** (nitzmahone)
  
  - Pipelining support
  - Become support
  - Integrated kerberos ticket management (via ansible_user/ansible_password)
  - Switch PS input encoding to BOM-less UTF8
  - Server 2016 support/testing (now RTM’d)
  - Modularize Windows module_utils (allow N files)
  - Declarative argspec for PS / .NET
  - Kerberos encryption (via notting, pywinrm/requests_kerberos/pykerberos)

- **Windows modules** (nitzmahone)

  - win_domain module
  - win_domain_membership module
  - win_domain_controller module
  - win_dns_client module
  - win_wait_for module
  - win_disk_image module
  - Updates to win_chocolatey, adopt to core (stretch)
  - Updates/rewrite to win_unzip, adopt to core (stretch)
  - Updates to win_updates, adopt to core (stretch)
  - Updates to win_package, adopt to core (+ deprecate win_msi)
  
- **Azure modules** (nitzmahone/mattclay)

  - Ensure Azure SDK rc6/RTM work
  - Move tests from ansible/azure_rm repo to ansible/ansible
  - Update/enhance tests
  - Expose endpoint overrides (support AzureChinaCloud, Azure Stack)
  - Get Azure tests running in CI (stretch, depends on availability of sponsored account)
  - azure_rm_loadbalancer module (stretch)
  
- **Networking**

  - Code stability and tidy up
  - Extend testing
  - User facing documentation
  - *Persistent connection manager*
  - Netconf/YANG implementation (only feature)
  - Deferred from 2.2: Network facts modules (sros)

- **Python3**

  - For 2.3:
    - We want all tests to pass (majority do but there’s 10-20 that still need fixes)
    - If users report bugs on python3, these should be fixed and will prioritize our work on porting other modules.
  - Still have to solve the python3-only and python2-only modules.  Thinking of doing this via metadata.  Will mean we have to use metadata at the module_common level.  Will also mean we don’t support py2-only or py3-only old style python modules. 
  - Note: Most of the currently tested ansible features now run.  But there’s still a lot of code that’s untested.

- **Testing and CI** (mattclay)  

  - Static Code Analysis - Create custom pylint extensions to automate detection of common Ansible specific issues reported during code review. Automate feedback on PRs for new code only to avoid noise from existing code which does not pass.
  - Test Reliability - Eliminate transient test failures by fixing unreliable tests. Reduce network dependencies by moving network resources into httptester.
  - Enable Remaining Tests - Implement fixes for OS X, FreeBSD and Python 3 to enable the remaining blacklisted tests for CI.
  - Windows Server 2016 - Add Windows Server 2016 to CI when official AMIs become available.
  - Repository Consolidation - Update CI to maintain and improve upon existing functionality after repository consolidation.

- **Amazon resources** (ryansb)

  - Refactor ec2.py (but first, better testing)
  - ELB version 2
  - Multifactor authentication support (STS feature, affects all modules)
  - CloudFormation YAML, cross-stack reference, and roles support
  - ECS module refactor
  - AWS module unit testing w/ placebo (boto3 only)

- **Plugin Loader**

  - Add module_utils to the plugin loader (feature)
  - Split plugin loader: Plugin_search, plugin_loader (modules only use first)(Stretch goal)
  - Add a ‘ansible-ssh’ convenience and debugging tool
    - Tool to invoke an interactive ssh to a host with the same args/env/config that ansible would.
      - There are at least three external versions
      - https://github.com/2ndQuadrant/ansible-ssh
      - https://github.com/haad/ansible-ssh
      - https://github.com/mlvnd/ansible-ssh