Difference between revisions of "Google Summer of Code Recommendations for Students"

From OSGeo
Jump to navigation Jump to search
(→‎How to get in contact via IRC: replace old section with a link to IRC page)
 
(16 intermediate revisions by 4 users not shown)
Line 3: Line 3:
 
[[Image:Osgeo-logo.png|300px|link=http://www.osgeo.org]]
 
[[Image:Osgeo-logo.png|300px|link=http://www.osgeo.org]]
 
</center>
 
</center>
 
-----
 
* Back to the main OSGeo [[Google Summer of Code 2018]] wiki page.
 
* Check out the [[Google_Summer_of_Code_2018_Ideas | Ideas web page]] or propose your own!
 
 
-----
 
 
  
 
== How to get in contact with your potential mentors ==
 
== How to get in contact with your potential mentors ==
Line 42: Line 35:
  
 
Consider that mentors are being contacted by several students that apply for the same project. A way to show that you are the best candidate, is to demonstrate that you are familiar with the software and you can code. How? Browse the bug tracker, fix some bugs and propose your patch in mailing list, and/or ask mentors to challenge you! Moreover, bug fixes are a great way to get familiar with the code.
 
Consider that mentors are being contacted by several students that apply for the same project. A way to show that you are the best candidate, is to demonstrate that you are familiar with the software and you can code. How? Browse the bug tracker, fix some bugs and propose your patch in mailing list, and/or ask mentors to challenge you! Moreover, bug fixes are a great way to get familiar with the code.
 +
 +
Former contributions to open source might be an asset and increase your chances of being selected.
  
 
=== Demonstrate your intention to stay ===
 
=== Demonstrate your intention to stay ===
Line 64: Line 59:
 
We welcome students to contact relevant developer communities within OSGeo umbrella before submitting their application into GSoC official website. If in doubt for which project(s) to contact, send the mail to both soc and discuss mailing lists.
 
We welcome students to contact relevant developer communities within OSGeo umbrella before submitting their application into GSoC official website. If in doubt for which project(s) to contact, send the mail to both soc and discuss mailing lists.
  
We recommend browsing past years' ideas pages, to look for ready-to-use projects, and to get an idea of the expected amount of work for a valid GSoC proposal. Read [https://google.github.io/gsocguides/student/writing-a-proposal here] how to write a nice proposals. Remember to use the template below. 
+
We recommend browsing past years' ideas pages, to look for ready-to-use projects, and to get an idea of the expected amount of work for a valid GSoC proposal. Read [https://google.github.io/gsocguides/student/writing-a-proposal here] how to write a nice proposals.  
  
Developers will then give feedback and prepare a small coding test (programming exercise or bug fix). See [https://developers.google.com/open-source/gsoc/help/responsibilities GSoC Roles and Responsibilities] to understand a successful teamwork and interplay of project, mentors and students.
+
Remember to use the template below. The same template, for your convenience, can be downloaded also from [https://github.com/OSGeo/gsoc/blob/master/proposal_template.md github]. After filling the template and detailing the proposal, you must follow the guidelines given by Google to submit it. Remember to submit your proposal well in advance, so that you can make the most out of the feedback from mentors and the community at large and refine your proposal until final deadline.
 +
 
 +
Developers will give feedback and prepare a small coding test (programming exercise or bug fix). See [https://developers.google.com/open-source/gsoc/help/responsibilities GSoC Roles and Responsibilities] to understand a successful teamwork and interplay of project, mentors and students.
  
 
As a general remark, we know that late submissions are not our best shot, as we usually find them incomplete, so be aware that the sooner you submit your proposals, the better chances you have to adjust them to mentors' requirements, and in the end, better chances to be selected.  
 
As a general remark, we know that late submissions are not our best shot, as we usually find them incomplete, so be aware that the sooner you submit your proposals, the better chances you have to adjust them to mentors' requirements, and in the end, better chances to be selected.  
Line 72: Line 69:
 
If you submit your proposal as "final", mentors cannot access it until deadline. So, unless you also share the google docs as public, we don't have a way to give you feedback and we will be evaluating your final proposal as it is, so you have less chances, or none at all if your proposals hasn't been discussed anywhere in public channels.  
 
If you submit your proposal as "final", mentors cannot access it until deadline. So, unless you also share the google docs as public, we don't have a way to give you feedback and we will be evaluating your final proposal as it is, so you have less chances, or none at all if your proposals hasn't been discussed anywhere in public channels.  
  
When you share your proposal, always allow comments! If you share it in view only, mentors can't give you feedback.
+
IMPORTANT: When you share your proposal, always allow comments! If you share it in view only, mentors can't give you feedback.
  
 
Remember that GSoC is a highly competitive program, we prioritize quality over quantity, this means that we only accept excellent proposals. Submitting a sloppy proposal it's just a useless waste of time for you and for mentors.
 
Remember that GSoC is a highly competitive program, we prioritize quality over quantity, this means that we only accept excellent proposals. Submitting a sloppy proposal it's just a useless waste of time for you and for mentors.
Line 100: Line 97:
 
==== 3. Timeline ====  
 
==== 3. Timeline ====  
 
* Now split your project idea in smaller tasks. Quantify the time you think each task needs. Finally, draw a detailed project plan (timeline) including the dates covering all period of GSoC. Don’t forget to include also the days in which you don’t plan to code, because of exams, holidays etc.  
 
* Now split your project idea in smaller tasks. Quantify the time you think each task needs. Finally, draw a detailed project plan (timeline) including the dates covering all period of GSoC. Don’t forget to include also the days in which you don’t plan to code, because of exams, holidays etc.  
* Note that by the start of the official coding period, students should be ready to start coding right away. Activities such as: initial research, set up working environment, choose tools to be used in the project, set up repository, etc must be carried out during [[Google_Summer_of_Code_Recommendations_for_Students#Bonding_period | bonding period]]. In your timeline, please add also activities that you will be carry out during the bonding period.
+
* The workload should be split in weekly chunks.
 +
* Your timeline should contain actual dates, not "week 1", "week 2", etc.
 +
* Note that by the start of the official coding period, students should be ready to start coding right away. Activities such as: initial research, set up working environment, choose tools to be used in the project, set up repository, familiarize with the code base and with the mentors, etc must be carried out during [[Google_Summer_of_Code_Recommendations_for_Students#Bonding_period | bonding period]]. In your timeline, please add also activities that you will be carry out during the bonding period.
 
* Do you understand this is a serious commitment, equivalent to a full-time paid summer internship or summer job?  
 
* Do you understand this is a serious commitment, equivalent to a full-time paid summer internship or summer job?  
* Do you have any known time conflicts during the official coding period?
+
* Do you have any known time conflicts during the official coding period? (Jobs, vacations, etc.)
  
 
==== 4. Studies ====  
 
==== 4. Studies ====  
Line 110: Line 109:
 
==== 5. Programming and GIS ====  
 
==== 5. Programming and GIS ====  
 
* Computing experience: operating systems you use on a daily basis, known programming languages, hardware, ecc.
 
* Computing experience: operating systems you use on a daily basis, known programming languages, hardware, ecc.
* GIS experience as a user:
+
* GIS experience as a user
* GIS programming and other software programming:
+
* GIS programming and other software programming
 +
* Briefly mention and link to former open source contributions
  
 
==== 6. GSoC participation ====  
 
==== 6. GSoC participation ====  
* Have you participated to GSoC before?  
+
* Have you participated in GSoC before?  
 
* How many times, which year, which project?
 
* How many times, which year, which project?
 
* Have you applied but were not selected? When?
 
* Have you applied but were not selected? When?
* Have you submitted/will you submit another proposal for this year's GSoC to a different org?
+
* Have you submitted/will you submit another proposal for this year's GSoC to a different org? Which one?
  
 
== What to expect after application ==
 
== What to expect after application ==
Line 144: Line 144:
 
=== Weekly reports ===
 
=== Weekly reports ===
  
Every week, by Sunday, we expect to see a report posted to the soc@osgeo and the developer mailing list of your project, that at least answers the following questions:
+
Every week, by Sunday, we expect to see your weekly progress report posted to the soc@osgeo and the developer mailing list of your project. You are requested to send the report even if you didn't code because of exams or holidays, or any other reason. The report should to contain the title of the project in the subject, the link to your wiki page, the link to the public repository of your weekly commits and at least the answers to these 3 questions:
  
 
# What did you get done this week?
 
# What did you get done this week?
Line 153: Line 153:
 
[http://en.wikipedia.org/wiki/Scrum_(development) Scrum] [http://en.wikipedia.org/wiki/Agile_software_development development process].  
 
[http://en.wikipedia.org/wiki/Scrum_(development) Scrum] [http://en.wikipedia.org/wiki/Agile_software_development development process].  
  
If you want, feel free to write *more*. But three sentences is the bare minimum.
+
If you want, feel free to expand your report, however this is the minimum required.  
 
 
Please explicitly mention your project in the subject and in the introduction to the e-mail.  
 
  
 
'''IT IS VERY IMPORTANT THAT YOU SEND YOUR PROGRESS REPORTS ON TIME''', if you don't send this email your mentors will start to get twitchy, and *especially* if they don't get any responses to their emails / don't see you on IRC. Twitchy mentors is not what we want. If you are blocked by finals, that's OK. Just tell us about it up front, be honest, and we'll work around it. If you don't know how to proceed and your mentor isn't answering, *definitely* tell about it. The SoC project admins will always be available. Basically the point is that you open up the communication channels, and keep them open. That way you will have a super summer, and get paid ;)
 
'''IT IS VERY IMPORTANT THAT YOU SEND YOUR PROGRESS REPORTS ON TIME''', if you don't send this email your mentors will start to get twitchy, and *especially* if they don't get any responses to their emails / don't see you on IRC. Twitchy mentors is not what we want. If you are blocked by finals, that's OK. Just tell us about it up front, be honest, and we'll work around it. If you don't know how to proceed and your mentor isn't answering, *definitely* tell about it. The SoC project admins will always be available. Basically the point is that you open up the communication channels, and keep them open. That way you will have a super summer, and get paid ;)
Line 187: Line 185:
 
== How to get in contact via IRC ==
 
== How to get in contact via IRC ==
  
Primary channel:
+
See [[IRC]] page
 
 
* '''#osgeo''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=osgeo browser])
 
 
 
GSoC @ OSGeo inter-project discussions:
 
 
 
* '''#osgeo-soc''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=osgeo-soc browser])
 
  
Project irc channels:
 
  
* '''#gdal''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=gdal browser])
 
* '''#geoserver''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=geoserver browser])
 
* '''#geotools''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=geotools browser])
 
* '''#grass''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=grass browser])
 
* '''#gvsig''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=gvsig browser])
 
* '''#mapguide''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=mapguide browser])
 
* '''#mapnik''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=mapnik browser])
 
* '''#mapserver''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=mapserver browser])
 
* '''#openlayers''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=openlayers browser])
 
* '''#opticks''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=opticks browser])
 
* '''#osgeolive''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=osgeolive browser])
 
* '''#ossimplanet''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=ossimplanet browser])
 
* '''#ossimplanet''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=ossimplanet browser])
 
* https://gitter.im/pgRouting/pgrouting
 
* '''#postgis''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=postgis browser])
 
* '''#qgis''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=qgis browser])
 
* '''#udig''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=udig browser])
 
* '''#geonode''' on freenode.net (connect directly in your [http://webchat.freenode.net/?channels=geonode browser])
 
  
 
[[Category: Google Summer of Code]]
 
[[Category: Google Summer of Code]]

Latest revision as of 02:29, 9 March 2023

GSoC2016Logo.jpg @ Osgeo-logo.png

How to get in contact with your potential mentors

Since OSGeo is an umbrella organisation for multiple project communities, each community has their own discussion and development Mailing Lists.

OSGeo mailing lists of interest for GSoC students:

Please start here, when contacting us for the first time with questions about Google Summer of Code.
  • To contact OSGeo's GSoC admin team directly (only for private matters that can't be shared in SoC ML):

How to increase your chances of being selected

If you put yourself in the shoes of the mentor that should select the student, you'll immediately realize that there are some behaviours that are usually rewarded. Here's some examples.

Be proactive

  • Mentors are more likely to select students that openly discuss the existing ideas and / or propose their own. It is a bad idea to just submit your idea only in the Google web site without discussing it, because it won't be noticed. Mentors and developers discuss ideas mostly in mailing lists.
  • It is a bad idea just listing your programming skills and waiting for the mentors to guide you towards next steps. Mentors reward students that show genuine interest in the projects they are willing to develop, propose improvements on their own and make pertinent questions. Remember that it is up to you, and not to the mentor, decide the software you want to work on and the idea to develop. It is not the mentor's job to do that for you.

Discuss your idea in public channels

  • Even if you have had some contact with a potential mentor, remember that the proposals discussion must happen in public channels, as it is always the case in open source communities.
  • It is a good idea to engage the individual dev lists and find a community that you are interested in working with and start building a relationship with that community. It is the community that decides which of the candidates they want to back, based on the value of the project, and whether or not they think the student will be successful.

Demonstrate your skills

Consider that mentors are being contacted by several students that apply for the same project. A way to show that you are the best candidate, is to demonstrate that you are familiar with the software and you can code. How? Browse the bug tracker, fix some bugs and propose your patch in mailing list, and/or ask mentors to challenge you! Moreover, bug fixes are a great way to get familiar with the code.

Former contributions to open source might be an asset and increase your chances of being selected.

Demonstrate your intention to stay

Students that are likely to disappear after GSoC are less likely to be selected. This is because there is no point in developing something that won't be maintained. And moreover, one scope of GSoC is to bring new developers to the community.

RTFM

Read the relevant information about GSoC in the wiki / web pages before asking. Most FAQs have been answered already!

Application instructions

We welcome students to contact relevant developer communities within OSGeo umbrella before submitting their application into GSoC official website. If in doubt for which project(s) to contact, send the mail to both soc and discuss mailing lists.

We recommend browsing past years' ideas pages, to look for ready-to-use projects, and to get an idea of the expected amount of work for a valid GSoC proposal. Read here how to write a nice proposals.

Remember to use the template below. The same template, for your convenience, can be downloaded also from github. After filling the template and detailing the proposal, you must follow the guidelines given by Google to submit it. Remember to submit your proposal well in advance, so that you can make the most out of the feedback from mentors and the community at large and refine your proposal until final deadline.

Developers will give feedback and prepare a small coding test (programming exercise or bug fix). See GSoC Roles and Responsibilities to understand a successful teamwork and interplay of project, mentors and students.

As a general remark, we know that late submissions are not our best shot, as we usually find them incomplete, so be aware that the sooner you submit your proposals, the better chances you have to adjust them to mentors' requirements, and in the end, better chances to be selected.

If you submit your proposal as "final", mentors cannot access it until deadline. So, unless you also share the google docs as public, we don't have a way to give you feedback and we will be evaluating your final proposal as it is, so you have less chances, or none at all if your proposals hasn't been discussed anywhere in public channels.

IMPORTANT: When you share your proposal, always allow comments! If you share it in view only, mentors can't give you feedback.

Remember that GSoC is a highly competitive program, we prioritize quality over quantity, this means that we only accept excellent proposals. Submitting a sloppy proposal it's just a useless waste of time for you and for mentors.


Template

1. Contact details

  • Name and surname:
  • Nickname:
  • Country:
  • Email:
  • Phone (we will not call you, unless you will become unreachable by email/IM for more than a week without warning):
  • Public repository/ies:
  • Personal blog (optional):
  • Twitter/Identica/LinkedIn/others:

2. Your idea

  • OSGeo or guest software:
  • Title: (please include the name of the member project as part of the title, for example: "Gee Whiz Foobar 2001 for QGIS")
  • Brief description of the idea. e.g. "My project will focus on xxx".
  • The state of the software BEFORE your GSoC. For example, if you want to make a GUI, you can say: "In the software XYZ, when I want to use the tool xxx, I have to manually edit the file yyy. "
  • The addition that your project will bring to the software. In the same example: "With the GUI that I intend to create, it will be possible to use the tool xxx via graphical user interface".
  • Future developments. How can your project be expanded or maintained after GSoC is over.

3. Timeline

  • Now split your project idea in smaller tasks. Quantify the time you think each task needs. Finally, draw a detailed project plan (timeline) including the dates covering all period of GSoC. Don’t forget to include also the days in which you don’t plan to code, because of exams, holidays etc.
  • The workload should be split in weekly chunks.
  • Your timeline should contain actual dates, not "week 1", "week 2", etc.
  • Note that by the start of the official coding period, students should be ready to start coding right away. Activities such as: initial research, set up working environment, choose tools to be used in the project, set up repository, familiarize with the code base and with the mentors, etc must be carried out during bonding period. In your timeline, please add also activities that you will be carry out during the bonding period.
  • Do you understand this is a serious commitment, equivalent to a full-time paid summer internship or summer job?
  • Do you have any known time conflicts during the official coding period? (Jobs, vacations, etc.)

4. Studies

  • What is your School and degree?
  • Would your application contribute to your ongoing studies/degree? If so, how?

5. Programming and GIS

  • Computing experience: operating systems you use on a daily basis, known programming languages, hardware, ecc.
  • GIS experience as a user
  • GIS programming and other software programming
  • Briefly mention and link to former open source contributions

6. GSoC participation

  • Have you participated in GSoC before?
  • How many times, which year, which project?
  • Have you applied but were not selected? When?
  • Have you submitted/will you submit another proposal for this year's GSoC to a different org? Which one?

What to expect after application

Now that you have submitted your application, it's time for you to set up your development environment and get familiar with the code of the software you want to develop for. Ask the developers to test you with a small coding task, or browse the bug tracker and submit a patch for a bug.

Bonding period

Bonding period does not mean relax. During bonding period, you are supposed to do all preparation in order to be able to start coding immediately the first week of actual coding period. These activities entail:

  • set up your dev environment: compile the source code, etc;
  • getting familiar with the source code, the dev documentation, programming manual and all the material that your mentors suggest;
  • start coding for bug fixes not necessarily related to your project;
  • scratching and pseudocoding your project;
  • set up your repository, familiarize with version control systems such as git / svn etc;
  • set up your wiki page, where you will describe your project and keep track of your weekly progresses;
  • get in touch with the community: introduce yourself in soc and dev mailing list, introduce your project and receive feedback.

What to expect during the summer

Be prepared to be in constant communication with your mentors and project

You and your mentors will decide on the specifics, but we will expect you and your mentor to communicate *a lot*. Part of the idea of SoC is to integrate you into the developer community, so you should get involved with them from the start. The more you communicate the easier it will be. Don't be afraid that the mentors will request your phone number. It is only to make sure that we can reach you in case of problems, like making sure you get paid.

University exams and semester terms vary widely, if we know in advance that you need a week off to study, or that you've already scheduled a short vacation to somewhere off the grid, that's fine and won't count against you. But you need to communicate this up front so we can make a plan to work around it.

Weekly reports

Every week, by Sunday, we expect to see your weekly progress report posted to the soc@osgeo and the developer mailing list of your project. You are requested to send the report even if you didn't code because of exams or holidays, or any other reason. The report should to contain the title of the project in the subject, the link to your wiki page, the link to the public repository of your weekly commits and at least the answers to these 3 questions:

  1. What did you get done this week?
  2. What do you plan on doing next week?
  3. Are you blocked on anything?

These questions BTW are the same as are used in real-work, when developing with the Scrum development process.

If you want, feel free to expand your report, however this is the minimum required.

IT IS VERY IMPORTANT THAT YOU SEND YOUR PROGRESS REPORTS ON TIME, if you don't send this email your mentors will start to get twitchy, and *especially* if they don't get any responses to their emails / don't see you on IRC. Twitchy mentors is not what we want. If you are blocked by finals, that's OK. Just tell us about it up front, be honest, and we'll work around it. If you don't know how to proceed and your mentor isn't answering, *definitely* tell about it. The SoC project admins will always be available. Basically the point is that you open up the communication channels, and keep them open. That way you will have a super summer, and get paid ;)

During past years this weekly report proved to be very popular among the students and mentors alike, so we will keep it up.

Code repository and documentation

Publishing your progress online and publicly is a GSoC requirement. Therefore, all students have to decide, before GSoC coding period starts, where to publish the code they will write. We ask students to give the link to the public repository in the first weekly report.

The possibilities are:

  • get a sandbox in your software project's repository (your mentor will tell you how to get write access)
  • work on a branch of the main code repository (for centralized versioning systems like SVN)
  • work on a fork of the code repository (for DCVS like Mercurial and Git)
  • work on an independent codebase (if you are developing a plugin or some other extra functionality that is not yet part of main codebase)

Your mentor is the best guide regarding this choice. Please discuss it as soon as possible, and learn how to use the related version control tool well before GSoC coding starts.

Documentation of your code is important! Don't leave all documentation writing to the last weeks of GSoC. It makes sense to outline it at the beginning of coding period, then refine it while you code. It is an important support to coding, as it is a mirror of the overall plan for the summer, and an essential source of information for who will use your code.

Wiki page and blogs

In addition to weekly reports we require you to maintain a wiki or blog page for your project. You should store your weekly reports there and add other information, like how to compile and test your program. If applicable add screenshots and other nice info.

Wiki and/or blog space can and will be provided by OSGeo if your project doesn't have anything already set up for this. Alternatives may be code repositories with wiki/blog functionality like GitHub, GitLab or Bitbucket.

We plan to link all of the students' blogs to the OSGeo Planet blog aggregator for maximum community exposure and hopefully early feedback from the experts who read it, which may save you a lot of time and trouble if, for example, some obscure wheel has already been invented by another partner project.

Final reports from those blogs and wiki pages will be collected into a OSGeo-of-code posting about what everyone did during the summer, ensuring you long lasting fame and fortune. (Or failing that, a bit of public press, a bit of cash from Google, and a lot of gratitude and kudos from us, your peers.)

How to get in contact via IRC

See IRC page