Version 13 (modified by dukeleto, 11 years ago)


This page lists detailed descriptions of tasks for Parrot Foundation and The Perl Foundation Google Code-In 2010.

1. What is Google Code-in?

Following on from the success of the Google Summer of Code™ program, Google is holding a contest for pre-university students (e.g., high school and secondary school students 13-18) called  Google Code-In with the aim of encouraging young people to participate in open source. We will work with open source organizations, each of whom will provide a list of tasks to be completed by student contestants. Tasks can be anything a project needs help with, from bug fixes to writing documentation to user experience research.

2. What are the goals of this contest?

Google Code-in (GCI) is intended to help students who may have wanted to get involved in open source but didn't know where to start. By working through the tasks suggested by organizations, contestants will be given the opportunity to engage with the open source community and get involved. The participating open source projects gain the benefit of additional contributions to their project, often in important areas that may get overlooked for whatever reason.

It is Google's not so secret hope that the student contestants of today will be long-term contributors to these and other open source projects in the future.


Tasks will typically fall into the following categories:

  1. Code: Tasks related to writing or refactoring code
  2. Documentation: Tasks related to creating/editing documents
  3. Outreach: Tasks related to community management and outreach/marketing
  4. Quality Assurance: Tasks related to testing and ensuring code is of high quality
  5. Research: Tasks related to studying a problem and recommending solutions
  6. Training: Tasks related to helping others learn more
  7. Translation: Tasks related to localization
  8. User Interface: Tasks related to user experience research or user interface design and interaction

Proposed tasks (more needed)

Task # 1: Make reflect current development and be more useful

Potential Mentors: ?

Background Required: Familiar with HTML, CSS, RSS

Details: The main web site is currently not dynamic enough. It is hard to see what is going on in our community right now from our main entry page. This task will make usability improvements to our site such as: List the last few commits to our codebase, giving links to relevant mailing lists and irc channels (and logs), summarizing recent blog posts from Planet Parrot, etc. PLEASE ADD MORE DETAIL.

Task # 2: Convert tests written in perl5 to pir - This could/would be multiple tasks

Potential Mentors: mikehh, ?

Background: Perl 5

Details: A lot of our tests are still written in perl5 or a combination of perl5 with pir in CODE/OUTPUT blocks. Ultimately we would like to get rid of any dependency on perl5. We will put forward a list of tests that still need converting and set them up as a tasks with one or more tests to be converted.

Task # 3: Increase test coverage of PMCs - This represents several tasks.

Potential Mentors: cotto, ?

Background: familiarity with  PIR and C, Perl 5 in some cases.

Details: Many of our  PMCs don't have complete test coverage. Although 100% coverage may not be possible in all cases, we can do better. We will provide a list of PMCs which need increased test coverage and notes about any PMCs which may provide difficulties in reaching 100%. A task will be complete when, at the mentor's discretion, a PMC's coverage is increased as much as is practical, ideally to 100%. This task requires the use of PIR, but increasing test coverage will usually require a small and easily-learned subset of PIR.

Task # 4: Increase test coverage of Math::Primality

Potential Mentors: bubaflub

Background: Perl 5, Prime numbers, Devel::Cover

Details: Math::Primality is a Perl 5 CPAN module that has advanced prime-checking algorithms. It was a GSoC project in 2009. Currently some new algorithms were added, but they don't have proper test coverage. Having better test coverage is necessary because people will rely on the correctness of the algorithms in this module for cryptography and number theory applications. This task will involve the student learning how to build and test Math::Primality, as well as analyzing the test coverage with the Devel::Cover CPAN module. When parts of the code are identified that need more tests, the students will work with the mentor to write tests that verify those parts of the code work correctly.