Actions

Difference between revisions of "Development Team"

From Joomla! Documentation

(5 intermediate revisions by 2 users not shown)
Line 6: Line 6:
 
== Positions, responsibilities and roles ==
 
== Positions, responsibilities and roles ==
  
The '''Development Workgroup Coordinator''' has the overall lead on Joomla! development and has the following responsibilities:
+
The '''Development Work group Coordinator''' has the overall lead on Joomla! development and has the following responsibilities:
 
# Will take care of properly planning the progress through the development stages for the various working groups. Proper planning includes: architectural design, coding stages, testing stages, release stages etc.  
 
# Will take care of properly planning the progress through the development stages for the various working groups. Proper planning includes: architectural design, coding stages, testing stages, release stages etc.  
# Will take care of basic communication to all surrounding workgroups. Arrange structure for testing and documentation, linking development effort to the other roles of the workgroups.  
+
# Will take care of basic communication to all surrounding work groups. Arrange structure for testing and documentation, linking development effort to the other roles of the work groups.  
 
# Will take care of standards and guidelines that need to be followed within the development workgroups (not writing them myself, but just arrange that these are created).  
 
# Will take care of standards and guidelines that need to be followed within the development workgroups (not writing them myself, but just arrange that these are created).  
# Will write a roadmap proposal for the Core team, and in later stages propose it to the community. Process any feedback, but guarding the overall goals of the project.  
+
# Will write a road map proposal for the Core team, and in later stages propose it to the community. Process any feedback, but guarding the overall goals of the project.  
# Will take care of periodical communication to the community: doing a blog, but also taking the road to the PR workgroup.  
+
# Will take care of periodical communication to the community: doing a blog, but also taking the road to the PR work group.  
#Will define some workgroup membership guidelines, and try to implement them into the workgroups. Non active, or non functional workgroup members can be removed, for this see the "Status" section.  
+
#Will define some work group membership guidelines, and try to implement them into the work groups. Non active, or non functional work group members can be removed, for this see the "Status" section.  
# Will invite new members to the workgroups (can also be done by the lead developers), and remove them when this is needed.  
+
# Will invite new members to the work groups (can also be done by the lead developers), and remove them when this is needed.  
 
# Will determine which lead developers are in the team.
 
# Will determine which lead developers are in the team.
 
# Guards the progression on the pre-defined project goals.
 
# Guards the progression on the pre-defined project goals.
  
A '''Lead Developer''' is a special development '''role''' within the development work group. There is no limit on the number of lead developers but the general rule is, 1 lead developer for every 5-10 developers, and in some occasions one lead developer per specific project goal (such as a main release). A lead developer has the following responsibilities:
+
A '''Development working group coordinator''' his/her main responsibility is to organize everything around Joomla! development. This is actually one of the very few official positions. The Development working group coordinators set direction, organize the team and do general overview for Joomla! development.
# Does architectural design for major and minor releases.
+
# Does final code review before code gets submitted to the trunk.
+
# Guards the general integrity of the Joomla! framework in terms of architectural concept implementation, coding standards and documentation.
+
# Does mentoring of development workgroup members.
+
# Does development of the Joomla! framework code.
+
# Does testing.
+
# Manages the creation of proper technical documentation of the framework (concepts, APIs, etc.).  
+
  
 
A '''Developer''' actually performs programming, testing and documentation tasks. A Developer can potentially assign himself to a wide variety of tasks but their individual abilities will likely determine which areas he/she will work on.
 
A '''Developer''' actually performs programming, testing and documentation tasks. A Developer can potentially assign himself to a wide variety of tasks but their individual abilities will likely determine which areas he/she will work on.
Line 30: Line 23:
 
# Does testing.
 
# Does testing.
 
# Follows [[Development guidelines]].  
 
# Follows [[Development guidelines]].  
# Works on technical documentation of all aspects of the Joomla! framework.  
+
# Works on technical documentation of all aspects of the Joomla! framework.
 +
 
 +
== Team membership ==
 +
 
 +
The development work group aims at the development of a cutting edge, state of the art Web Content Management application framework. This workgroup is the driving force behind new versions, and building it. Along with the other working groups we try to realize this ambition.
 +
 
 +
We always seek for new talent. We are very sharp on who we want because the results of this workgroup determines what the quality of Joomla! is. Most of the times we get in touch with you when we see some interesting work around, but if you think you are the talent we seek you also can contact us. If you want to grab our attention, start [Sending in patches] so we actually can see what you do, and how you do. Before you do please bear the following in mind:
 +
 
 +
# You need to be available at least 8 hours per week.
 +
# Education (or still being a student) in informatics with knowledge of modern development methods and techniques.
 +
# (Outstanding) knowledge of programming techniques like patterns and object orientation.
 +
# Experience with PHP, (My)SQL and webservices.
 +
# Knowledge with the Joomla! application and CMS framework.
  
 
== Membership status ==
 
== Membership status ==
Line 69: Line 74:
 
* When he/she violates the Code of Conduct.
 
* When he/she violates the Code of Conduct.
 
* When the work team member is inactive for more then 6 months (see the membership status section above).
 
* When the work team member is inactive for more then 6 months (see the membership status section above).
 
+
<noinclude>[[Category:Development Working Group]]</noinclude>
[[Category:Development]]
+
[[Category:Working Groups]]

Revision as of 08:11, 20 September 2010

Workgroups development.jpg

The collaboration within the Joomla! Open-source project is based upon the trust and fun. We want to put as little hierarchy into this team as possible, and, if we actually do Joomla! (all together) this section will be superfluous. But for every team that exists of more than one person, a structure needs to be in place.

This team sometimes also is referred to as core-committers. Some of the members are also core-team members, but the term "core-comitter" refers to team members who have full commit access to the Joomla! code base.

Contents

Positions, responsibilities and roles

The Development Work group Coordinator has the overall lead on Joomla! development and has the following responsibilities:

  1. Will take care of properly planning the progress through the development stages for the various working groups. Proper planning includes: architectural design, coding stages, testing stages, release stages etc.
  2. Will take care of basic communication to all surrounding work groups. Arrange structure for testing and documentation, linking development effort to the other roles of the work groups.
  3. Will take care of standards and guidelines that need to be followed within the development workgroups (not writing them myself, but just arrange that these are created).
  4. Will write a road map proposal for the Core team, and in later stages propose it to the community. Process any feedback, but guarding the overall goals of the project.
  5. Will take care of periodical communication to the community: doing a blog, but also taking the road to the PR work group.
  6. Will define some work group membership guidelines, and try to implement them into the work groups. Non active, or non functional work group members can be removed, for this see the "Status" section.
  7. Will invite new members to the work groups (can also be done by the lead developers), and remove them when this is needed.
  8. Will determine which lead developers are in the team.
  9. Guards the progression on the pre-defined project goals.

A Development working group coordinator his/her main responsibility is to organize everything around Joomla! development. This is actually one of the very few official positions. The Development working group coordinators set direction, organize the team and do general overview for Joomla! development.

A Developer actually performs programming, testing and documentation tasks. A Developer can potentially assign himself to a wide variety of tasks but their individual abilities will likely determine which areas he/she will work on.

  1. Does development of the Joomla! framework code.
  2. Does testing.
  3. Follows Development guidelines.
  4. Works on technical documentation of all aspects of the Joomla! framework.

Team membership

The development work group aims at the development of a cutting edge, state of the art Web Content Management application framework. This workgroup is the driving force behind new versions, and building it. Along with the other working groups we try to realize this ambition.

We always seek for new talent. We are very sharp on who we want because the results of this workgroup determines what the quality of Joomla! is. Most of the times we get in touch with you when we see some interesting work around, but if you think you are the talent we seek you also can contact us. If you want to grab our attention, start [Sending in patches] so we actually can see what you do, and how you do. Before you do please bear the following in mind:

  1. You need to be available at least 8 hours per week.
  2. Education (or still being a student) in informatics with knowledge of modern development methods and techniques.
  3. (Outstanding) knowledge of programming techniques like patterns and object orientation.
  4. Experience with PHP, (My)SQL and webservices.
  5. Knowledge with the Joomla! application and CMS framework.

Membership status

Within the development work group, we recognize three membership statuses:

  1. Active - actively contributing on a week-by-week or day-by-day basis (or even more).
  2. On-leave - temporarily away from duties because of vacations, work commitments or other valid reasons but still in touch with regular communication channels.
  3. Inactive - Away from duties and responsibilities for a period of time and not in touch with regular communication channels.

A development team group member is considered active if they are contributing to a communication channel at least once a week and fulfilling a reasonable time commitment to the project. To prevent stagnant teams and blocking out new talent from getting into the development work group some limitations apply to the possible statuses described above:

  1. A development work group member may be on-leave for up to 3 months. After this period the team member will automatically be transferred to inactive status.
  2. A development work group member may be inactive for up to 6 months. After this period the team member will automatically be removed from the work group. When transferred from on-leave status to inactive, the total period a team member can be absent is 6 months.

In all cases it is important that the developers informs the work group coordinator or lead developer of his team that he/she is (planning to go) on leave or being inactive.

Conflict resolution

It would be naive to assume that a group of people can work together in perfect harmony. There are going to be times when someone feels they have been wronged. In these times the following procedure should apply:

  1. Talk privately to the person concerned.
  2. If you still believe grievances exists, then bring in one or two other people to help mediate.
  3. If this fails then take the issue to the workgroup coordinator.
  4. If this fails take the issue with the workgroup coordinator to the Joomla! project leader.
  5. If this fails take the issue to the whole Core team for final determination.

Team members are encouraged to self-mediate all disputes. In all situations, treat 'wounds' appropriately. A prick on the finger just needs a tissue for a couple of seconds. Some grazes and cut just need a Band-Aid to help heal well but will probably heal anyway if left untouched. More serious lacerations need immediate intervention for survival. If a wound is left to attract an infection then the obvious threat of gangrene is present.

Resignation

Everyone in Joomla! has their season and there are going to be times when someone needs to move on for various reasons. You should always feel comfortable to leave or have a holiday from the project, just inform the work group coordinator or better yet, let the whole team know by posting your absence to the mailing list (joomla-devel@googlegroups.com). If you are going to be unavailable for a period of time, please be considerate and:

  • Give reasonable notice in proportion to your role. Work group coordinator and Lead Developers should give around four weeks notice and other members at least one.
  • Make sure that your team knows what they have to take over when you leave. Do not put the Team in a position where they have to play detective to find out what you did, where things are, and what their status is, etc.

Removing members

A development team member will be removed:

  • When he/she violates the Code of Conduct.
  • When the work team member is inactive for more then 6 months (see the membership status section above).