Roadmap

Background: In recent years, Wikimedia Foundation's engineering planning has primarily taken place in a combination of internal goals documents and public project-level documentation. The purpose of this page is to establish a practice of sharing holistic engineering goals, initially primarily with a short term horizon, as a public document with open participation. See also: Previous months:
 * Product Whitepaper for Wikimedia Foundation product priority justifications; Strategic Plan for long-term WMF  goals, some of which are engineering goals
 * Roadmap/Archive for an earlier effort to create a roadmap more focused on point releases of the MediaWiki software
 * /2011/September
 * /2011/October
 * /2011/November
 * /2011/December
 * /2012/January
 * /2012/February
 * /2012/March
 * /2012/April
 * /2012/May
 * /2012/June
 * /2012/July
 * /2012/August

Item syntax: Examples:
 * Project name
 * [Qualifier keyword] Action item [Owner(s)] [Completion keyword]
 * New unicorn engagement
 * [Needs consensus] Deploy unicorns [Brion/Tim]
 * Deploy unicorns [Brion/Tim] [DONE]

Continuous Responsibilities

 * Code review
 * RT review / ops tasks
 * Community extension review and deployment
 * Bug triages and general bug fixes
 * New extension deployment (Review queue)
 * Labs maintenance
 * Test infrastructure maintenance
 * Recruitment and encouragement of volunteers
 * Monthly report and other engineering communications

Technical Operations

 * Datacenter migration
 * Memcached/Redis
 * Configure Redis server @TAMPA [Mark/Asher/Leslie]
 * Deploy MediaWiki changes to handle sessions from Redis@Tampa [Tim]
 * Deploy MediaWiki changes to dual-write all Memcache entries to Memcached and Redis@Tampa [Tim]
 * Disable Memcached@Tampa [Tim]
 * Configure Redis server @Eqiad [Mark/Asher/Leslie]
 * Test Redis replication from Tampa to Eqiad [Asher/Tim]
 * Wide Apache-on-Precise test deployment @ Tampa [Asher/Peter/Mark]
 * complete packaging, puppetising and testing of Image-Scalers @ Tampa [Peter/Mark/Faidon]
 * Limited ImageScalers-on-Precise deployment @ Tampa [Asher/Peter/Mark]
 * Swift
 * Full switch-over (disable NFS) [ongoing]
 * Initiate Eqiad Swift replication [RobH / Faidon / Ariel]
 * complete migration of the rest of contents from ms7 to Swift [Aaron]
 * Fundraising infrastructure buildup@ EQIAD [Jeff G]
 * migrate services (logging, puppet, deployment system) from silicon to boron/indium
 * move silicon to frack, re-image to provision/test activemq
 * deploy ganglia for new cluster
 * test/tune/deploy new payments infrastructure
 * document new infrastructure
 * Varnish
 * deploy Varnish with persistent store [Mark] [testing on mobile] - done
 * deploy Varnish with fixes to streaming video performance issues [Mark] - serving 10% traffic now; moving the rest in the coming week
 * Provision & Deploy Poolcounter servers@eqiad
 * Eqiad Deployment Host
 * Provision
 * migrate from tampa

Mobile / Offline

 * WLM bug fix v1.2.4
 * Wind down WLM
 * Sticky cookie issues
 * Begin backlog planning for new nav [DONE]
 * Beta updates
 * Left side nav
 * Watchlists
 * Login
 * Dynamic Sections
 * Move meta features -> prod
 * Analyze WLM data to guide next upload steps
 * Plan backlog for image triage
 * Hackathon planning
 * pickup any remaining redirects [office, chapters, ...]

Visual Editor

 * VisualEditor
 * API (implementation of 3 features) [IN PROCESS]
 * Feature implementation and bugfixing on VE according to 3 month plan [IN PROCESS]
 * Parsoid
 * C++ implementation of Parsoid [IN PROCESS]
 * Parsoid fixes for release (December date) [ONGOING]


 * Page Curation (fka Page Triage)
 * Keyboard shortcuts: spec [TOO COMPLEX]
 * Increase visibility of Special:NewPagesFeed (e.g., notice on Special:NewPages) [DONE]
 * Additional socialization [ONGOING]
 * Final deployment [9/20]


 * Article feedback
 * Link with page protection [IN PROCESS]


 * Echo_(Notifications) & Flow
 * Project planning for Notifications (in preparation for E2 team to start work once Page Curation is finished) [IN PROCESS]
 * UI and bugfixing of Echo [ONGOING]
 * see Performance engineering and Database Sharding for prep work on Echo & Flow


 * E3
 * Clicktracking/Analytics
 * E3 analytics, Clicktracking re-design [IN PROCESS]
 * Post-edit Feedback 2 [IN PROCESS]
 * Data analysis once experiment is complete [IN PROCESS]
 * Community Portal on en.wp
 * Continued click-tracking work on Community Portal (funnel analysis) [IN PROCESS]
 * Further UX improvements for Community Portal page on en.wp [TBD]
 * Account Creation User Experience
 * UI/UX mockups [DONE]
 * Development [IN PROCESS]
 * Clicktracking enablement - first iteration [DONE]

Multimedia

 * UploadWizard
 * One sprint devoted to UploadWizard bugs for WLM [Kaldari/Holmquist] [DONE]
 * Integration of Flickr GSoC work (requires operational infrastructure change) [COMPLETE/BLOCKED]
 * TimedMediaHandler
 * Bugfixing of player on test2 [IN PROCESS]
 * Deployment of transcoding boxes
 * Possible work on writing transcodes exclusively to Swift
 * Create production deployment plan

Support

 * ResourceLoader 2 -- mostly the Gadgets-extension work which is (as of June 2012) in a branch.
 * Testing existing gadgets on WMF labs for breakage [Timo] [IN PROCESS]
 * "Gadgets 3.0": Includes getting a version deployed/integrated, then a review of Salvatore's "Gadgets user  preferences" work, then a merge of Salvatore's work
 * Discussion of global scripts hosting [IN PROCESS]


 * Fundraising Engineering
 * Add Adyen payment processor [IN PROCESS]
 * Refactor PayPal, Moneybookers processors [IN PROCESS]

MediaWiki Core

 * Datacenter migration (see TechOps section above)
 * Git/Conversion (Chad/Antoine)
 * Have last of extensions out of SVN and into Git
 * Stage Gerrit 2.5 for testing
 * OAuth
 * Discuss at tech days/all staff [ChrisS]
 * Swift
 * See Swift section in Ops
 * MediaWiki 1.20/Roadmap
 * Bi-weekly deployment cycle continues
 * 1.20wmf11 [DONE]
 * 1.20wmf12 [ongoing]
 * Continuous integration
 * Admin tools development
 * Wikidata deployment
 * Code review of extensions [Sam, Tim]
 * Site performance

QA

 * use beta cluster hosting latest version of prod extensions (AFTv5, NewPagesFeed, etc.) for testing [Antoine/Chris] [IN PROGRESS]
 * engaged with all Features testing [CHRIS] [ONGOING]
 * contractor at work(?) [IN DISCUSSION]

Analytics

 * Cache Server Log Aggregation Plan [Dave, Otto] [IN PROGRESS]
 * Complete testing Kafka
 * Complete architectural suggestions document
 * Present to Ops, get signoff, throw party
 * Hand off Limn to new engineer [Dave] [pending]
 * Prototype of Data Warehouse [Dave, Otto] [pending]
 * Test CDH4 on Cassandra 1.x
 * Test DSE

Engineering Community Team

 * GSoC wrapup & postmortem [Sumana + volunteers]
 * Bug Wrangling [Bug Wrangler + volunteers]
 * Online or in-person QA trainings for the community [Technical Contributor Coordinator]
 * Preparation for upcoming events [Sumana, Technical Contributor Coordinator]
 * Tech Ambassadors Network [Guillaume]
 * Volunteer product management program [Guillaume]

i18n/L10n

 * Internationalization/Localization
 * Universal Language Selector
 * Version 1 development [IN PROGRESS]
 * User Experience / UI testing [ONGOING]
 * Technical documentation [TBD]
 * Project Lassi: Translate UX Improvements
 * User Experience / UI testing [IN PROGRESS]
 * Prototype development [IN PROGRESS]
 * Translate API
 * API definition [On Hold]
 * TTMServer
 * Labs setup of SOLR review DONE
 * Testing of SOLR / TTMServer DONE
 * Deployment to 7 wikis IN PROGRESS
 * Web Fonts
 * Adding languages [ONGOING]
 * Narayam
 * Adding input methods for other languages [ONGOING]
 * Project Milkshake
 * Design specification, API specification, development [IN PROGRESS]
 * Technical documentation [TBD]
 * Language search
 * Initial analysis [DONE]
 * Prototype initial concept [IN PROGRESS]
 * Integration into ULS [IN PROGRESS]

Technical Operations
Deploy Memcached/Redis @ Tampa [Mark/Asher/Tim] Replicate Redis to EQIAD [Mark/Asher/Tim] Deploy Etherpad Lite [Daniel/RobH] Deploy Mingle [RobH/DZ] Deploy eqiad application serving (Oct 15)

Features

 * New Pages Feed (fka Page Triage)
 * Additional feature development (only must-haves)
 * Article Creation Workflow
 * revisit for release
 * Changes to visual design to make ACW consistent with Design Toolkit
 * Echo_(Notifications)
 * Continued development of prototype for Mediawiki.org [Werdna/Vibha]
 * Global preferences for echo delivery
 * centralization and cross wiki notification delivery

(other) Editor Engagement

 * New Pages Feed (fka Page Triage)
 * Public launch of New Pages feed [mid Sept]
 * Keyboard shortcuts: spec [IN PROCESS]
 * Additional socialization [ONGOING]
 * Final features (metrics)
 * Descriptive statistics on NPF [Dario] [IN PROCESS]
 * Additional socialization and public announcement/launch
 * Article Creation Wizard: TBD
 * Article feedback
 * performance/db related changes to AFTv5 queries before scaling, + sharding (see Database sharding) [IN PROCESS]
 * (new features TBD pending scalability issues)
 * Other issues for enwp release (mobile, etc.)
 * Link with page protection [IN PROCESS]
 * Echo_(Notifications) & Flow
 * re-deployment of prototype for Mediawiki.org [Werdna/Vibha] [IN PROCESS]
 * UI and bugfixing of Echo [ONGOING]
 * Next set of features TBD
 * (see Performance engineering for infrastructure prep work:)
 * queueing & Echo
 * Database Sharding & Flow

MediaWiki Core

 * Datacenter migration (see TechOps section above)
 * Git/Conversion (Chad/Antoine)
 * Upgrade to 2.5
 * Mirror mediawiki-core to GitHub (waiting on Gerrit 2.5) [Chad]
 * Have last of extensions out of SVN and into Git
 * Have Lucene work underway upstream for 2.6 release cycle
 * Finish replicating all repos to GitHub
 * Begin researching how to get pull requests back in
 * Have gitweb replacement in place (probably GitBlit)
 * OAuth [ChrisS]
 * Swift
 * See Swift section in Ops
 * MediaWiki 1.20/Roadmap
 * Bi-weekly deployment cycle continues
 * 1.20wmf13
 * 1.20wmf14
 * Continuous integration
 * Admin tools development
 * Wikidata deployment
 * Code review of extensions [Sam, Tim]
 * Site performance
 * Lua scripting [Tim]

QA

 * use beta cluster hosting latest version of prod extensions (AFTv5, NewPagesFeed, etc.) for testing [Antoine/Chris] [IN PROGRESS]
 * engaged with all Features testing [CHRIS] [ONGOING]
 * contractor at work(?) [IN DISCUSSION]

Analytics

 * Cache Server Log Aggregation Plan [Dave, Otto] [IN PROGRESS]
 * Hand off Limn to new engineer [Dave] [pending]
 * Prototype of Data Warehouse [Dave, Otto] [pending]
 * Test CDH4 on Cassandra 1.x
 * Test DSE

Engineering Community Team

 * GSoC wrapup & postmortem [Sumana + volunteers]
 * Bug Wrangling [Bug Wrangler + volunteers]
 * Online or in-person QA trainings for the community [Technical Contributor Coordinator]
 * Community testing events [Technical Contributor Coordinator]
 * Preparation for upcoming events [Sumana, Technical Contributor Coordinator]
 * India hackathon in the fall? [Sumana, Technical Contributor Coordinator]
 * Tech Ambassadors Network [Guillaume]
 * Volunteer product management program [Guillaume]
 * UCOSP idea-wrangling

Parking lot and todos

 * Install Lua (Scribunto) on other Wikimedia wikis (probably sometime in 2013; see Goals)
 * Category collation
 * Patch waiting on Liangent for more work for full deployment


 * Queuing infrastructure work for Flow (who added this?)
 * Configuration management overhaul [Chad]
 * Evaluate WikiFactory from Wikia
 * Extension management -- depends on config mgmt revamp
 * Details of git migration (extension mgmt, permissions, code review tool, Gerrit-Jenkins integration, etc.)
 * More work on product backlogs for features and mobile
 * Ops section
 * Fundraising flesh-out
 * cf Wikimedia Platform Engineering and merge as appropriate
 * Namespace hacks for development of simple language wikipedias in languages other than English without server, database, or major wiki installation provisioning
 * Most popular related articles
 * Replicated session handling
 * HipHop deployment (deferred because Facebook has a different shiny new thing)
 * Extension:Configure (merge with config management?)
 * Unicode normalization considerations
 * Schema handling improvements (Abstracted database schema description, schema updaters to make the multiple schema variants for MySQL 4.0 and 5/UTF-8 more maintainable)
 * Parallelizable, restartable dump runner (notes; Clean up the currently fragile externaldump process, make our internal backups more reliable
 * OAI cleanup (Clean up OAI exporter and importer, add time-delay features
 * audit users of OAIPMH and check how search indexing uses it
 * Deletion queue system (notes; Human-helpful process improvements
 * Integrated heuristic checks, improved patrolling (human-helpful process improvements)
 * On-wiki namespace manager (Special:Namespaces) (original wikidata branch specs and see notes)
 * Wikidata (WMDE)
 * BlameMaps (WMDE)
 * graphical UI on top of improved backend for configuration management
 * Various HTTPS support fixes
 * Wikimedia server error page
 * Wikimedia operations history and architecture document
 * Disk-backed object cache
 * DB sharding
 * Help features
 * Mentoring features
 * Other real-time features, chat
 * Affiliation tools for WikiProjects [build on GlobalProfile]
 * Gadgets 2.0?
 * Interwiki transclusion
 * WMF cannot commit the time to merge this.
 * Replicated session handling [Tim Starling]
 * Relicense our Lucene contributions [future Lucene search engineer]