Drupal.org https://publish.mediacurrent.com/ en How to create a more findable Drupal issue https://publish.mediacurrent.com/blog/how-create-more-findable-drupal-issue <span class="field field--name-title field--type-string field--label-hidden">How to create a more findable Drupal issue</span> <div class="clearfix text-formatted field field--name-body field--type-text-with-summary field--label-hidden field__item"><p>As you’ve hopefully seen from <a href="http://www.mediacurrent.com/blog/whats-your-issue">my last blog post</a>, the Drupal issue queue is quite a powerful system and provides lots of options to help find an existing issue. That said, there’s the obvious situation when the particular task at hand has <em>not</em> been discussed before and a new issue needs to be created. So, lets look at some ways to make sure a new issue covers both the important points and includes useful details to help others find it.</p> <p>Before proceeding it’s important to decide whether the issue to be opened is for a security problem. <a href="http://drupal.org/security">Drupal’s dedicated security team</a> makes it one of the best open source projects around. When a security problem is found there’s a <a title="Drupal security procedure" href="http://drupal.org/node/101494">specific procedure to follow</a> that allows time to resolve the problem prior to disclosure, which helps avoid the situation of other sites being hacked. So, for our example we’ll deal with slightly more average issues.</p> <h3>Creating an Issue on Drupal.org</h3> <p>At the top of every project’s issue queue list is a link that simply says “Create a new issue”. It’s noteworthy that this link is purposefully <em>not</em> on the main project page, this way it forces visitors to search through the existing issues rather than immediately creating new ones; this greatly helps to reduce the amount of duplicate issues that are opened and keeps issue queues more focused.</p> <p>Once the “Create issue” page has opened, it’s worth noting that the page provides a link to the procedures page for filing a security report, should it be needed. There are also links provided to pages explaining best practices for filing issues and even a template that can be copied/pasted into the new issue form to be tailored for each specific need. Additionally, each project can add an extra message at the top of this page, for example the Panels issue form has links to the Panels issue submission guidelines and an article from Eric S. Raymond that explains “how to ask questions the smart way,” and is worth reading.</p> <p>Moving on from there, every issue belongs to a project. When the “Create issue” link is followed the project value will be automatically selected, so that doesn’t need any further thought.</p> <h3>Select your way to a better issue</h3> <p>The two most basic selectors on the form that need answering are the <em>Version</em> and <em>Category</em> fields. The former should be set to the specific version being used on the site, e.g. 7.x-2.5, 6.x-3.2-beta4, etc, or maybe 6.x-3.x-dev if the site is using a development snapshot. Meanwhile, the latter simply indicates whether the item being reported is a bug report, a feature request, or a support request (i.e. “can someone please help me?”); the “task” category tends to be used for issues internal to the module, e.g. planning for the next stable release. These are also two of the most basic filters used when a visitor is searching for an issue, and thankfully they’re pretty straight forward.</p> <p>One of the options that can be a little confusing is the <em>Component</em>. Projects start with a default list of “Code,” “Documentation,” “Miscellaneous” and “User interface.” Each project can customize the list and add others, so some, like Panels or Views, will have a plethora of options. What can occasionally be confusing is that the specific issue at hand may cover multiple items in the list, or it may not fit any of them overly well. I’ve found that it’s best to just pick something that’s at least partly appropriate, other contributors will help fine tune the selection later if needed.</p> <p>The final selector that needs some small consideration is the <em>Priority</em> field. The general rule of thumb is that “Critical” should only be selected if there’s a bug which causes data loss, “Major” is appropriate for large bugs or code changes that could have extensive repercussions for the project, and relatively insignificant or unimportant changes (spelling mistakes in help messages, color scheme adjustments, etc) should be marked as “Minor”. Everything else, which tends to be the vast majority of issues, should be simply marked as “Normal”, and the community &amp; maintainer(s) will collaborate to decide if this should be bumped to another priority.</p> <p>It’s worth pointing out that, as a matter of courtesy, unless the issue is a bug of significant importance, all issues should start at “Normal” and be adjusted as necessary. Furthermore all support requests should <em>always</em> be “Normal,” regardless of <em>your</em> need for an answer. While you may be on a deadline to finish a project and need an answer quickly, the module’s maintainer may be at home dealing with a sick child, tending to a new baby, on a much deserved vacation with their family, or just dealing with their own urgent project. So, be patient and you’ll eventually receive a response.</p> <p>The meat of the issue, the <em>Title</em> and <em>Description</em>, should be relatively straightforward. When reporting a bug make sure to describe the steps to recreate the issue, the result that was expected and what really happened. Similarly, support requests should explain the scenario and the point in using the module where help is needed. On the other hand, when describing a feature request make sure to give a good rationale for the change - there may be a solid reason for why the module currently works the way it does, so there might need to be a really good reason to change it. The last thing to note is that uploading screenshots can really help at times; just remember to click the <em>Upload</em> button after each one before another one can be uploaded.</p> <h3>Make it better</h3> <p>One suggestion from a co-worker is to pause for a moment before submitting the issue. Often times one of the hardest parts of life is to work out how to phrase a question correctly –sometimes the simple process of writing down a question might be enough to help work out a solution. Furthermore, writing down the issue might help identify the best words to describe a problem; this effort might then help doing another quick search through the issue queue, so it’s worth taking a quick moment to double-check before saving the issue.</p> <p>For more detailed requests or bug reports, and especially if you have the time to do it, there is an <a title="Official issue recommendation" href="http://drupal.org/node/1155816">official recommendation on the format</a> to use. Don’t let that put you off, though, remember that issues can be updated after the initial submission, so if further detail is required it can be added later.</p> <p>As with my suggestion for searching issues, it’s important to remember that the words used to describe the issue can help or hinder someone else’s efforts to find an issue. Because of this it’s worth using different words and phrases to describe the issue, e.g. instead of just saying “CSS” repeatedly add the words “theming”, “display”, etc, that may help others in the future.</p> <p>An important thing to remember is to be polite and helpful with requests rather than demanding or impatient. A large portion, if not the majority, of issue queue work is done during personal downtime – people are collaborating out of their own sense of compassion or interest in helping the project when they could otherwise be spending time with family or reading a book. With this in mind, requests politely asking questions or making suggestions will receive a much better response than complaints or demands.</p> <p>Lastly, don’t be afraid to make mistakes – the vast majority of Drupal contributors are really nice people who are happy to help others learn and improve their skills. And remember, further detail can always be added in follow-on comments as needed.</p> <p>Go forth and create new issues, when appropriate :)</p> <p><strong>Additonal Resources</strong></p> <p><a href="/blog/power-giving" target="_self">The Power of Giving</a></p> <p><a href="http://www.mediacurrent.com/blog/whats-new-drupal-8">What's new in Drupal 8?</a></p> <p><a href="http://www.mediacurrent.com/blog/webinar-building-drupal-features">Webinar: Building Drupal Features</a></p> <p> </p> <p> </p> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><a title="View user profile." href="/who-we-are/team/damien-mckenna" lang="" about="/who-we-are/team/damien-mckenna" typeof="schema:Person" property="schema:name" datatype="" class="username">Damien McKenna</a></span> <span class="field field--name-created field--type-created field--label-hidden">Mon, 04/08/2013 - 10:17</span> <div class="field field--name-field-tags field--type-entity-reference field--label-above"> <div class="field__label">Tags</div> <div class="field__items"> <div class="field__item"><a href="/tags/development" hreflang="en">Development</a></div> <div class="field__item"><a href="/tags/drupal" hreflang="en">Drupal</a></div> <div class="field__item"><a href="/tags/drupalorg" hreflang="en">Drupal.org</a></div> </div> </div> <div class="gatsby-iframe-container"><iframe class="gatsby-iframe" src="https://preview-misriptide.gtsb.io/blog/how-create-more-findable-drupal-issue"></iframe></div> Mon, 08 Apr 2013 14:17:21 +0000 Damien McKenna 824 at https://publish.mediacurrent.com 5 Tips for Drupal Newbies https://publish.mediacurrent.com/blog/5-tips-drupal-newbies <span class="field field--name-title field--type-string field--label-hidden">5 Tips for Drupal Newbies</span> <div class="clearfix text-formatted field field--name-body field--type-text-with-summary field--label-hidden field__item"><p>The attendee list at this week’s <a href="https://www.meetup.com/drupalatlanta/"><span style="text-decoration: underline;">Atlanta Drupal Meetup</span></a> group ran a wide gauntlet. There was a mix of business owners, newbies, marketers, and even someone with a Drupal.org ID under 1000. We broke up our normal presentation format and had informal talks about <a href="https://www.mediacurrent.com/blog/web-changing-and-so-drupal"><span style="text-decoration: underline;">Drupalcon Denver</span>,</a> the job market, and trends. As usual, we went around the room and allowed for introductions and announcements. When one of the attendees, we’ll call him “Jack”, was in the hot seat, he gave a typical hello, but then broke the introduction format and asked a question back to the crowd. He asked, “I’ve only been working with Drupal for a few weeks, what tips do you have for those that are just starting out?”</p> <!--break--></p> <p>You should have seen the room light up with excitement. I saw the same look on my wife’s face when she converted a friend into a <a href="http://hungergamesblog.com/">Hunger Games</a> fanatic–the look of “let me tell you how wonderful this is.”</p> <p>Below is a summary of the tips the group provided to this new Drupal’er:</p> <ol> <li><strong>Read Planet Drupal</strong> – A great aggregator site for all things Drupal. They have a content <a href="http://drupal.org/about/drupal-planet">upload policy</a>, so you know all the material you will be reading is “the real deal.”</li> <li><strong>Dig through Drupal.org</strong> – Where all Drupalers go to gather information, review modules, themes, groups, etc. Also, when looking through modules on <a href="http://drupal.org/">Drupal.org</a>, one tip provided by <a href="http://kentlester.com/">Kent Lester</a>, was look at the number of downloads. The larger number of downloads usually correlates with a better quality module.</li> <li><strong>Start with Drupal 7</strong> – This answer came when Jack asked if he should start a new site with Drupal 6, or just begin with 7. The resounding answer was start with <a href="http://drupal.org/drupal-7.0">Drupal 7</a>.</li> <li><strong>Read Pro Drupal Development</strong> – According to the group, immerse yourself <a href="http://www.drupalbook.com/">in the book</a>. It teaches you how to create modules, develop themes, and produce filters. It also covers the inner workings of each key part of Drupal, including user management, sessions, the node system, caching, and the various APIs available to you.</li> <li><strong>Watch DrupalCon/DrupalCamp Session videos</strong> – There are videos all over the web from previous DrupalCon’s and DrupalCamps. You can watch all of the 2012 <a href="http://blip.tv/drupalcondenver">DrupalCon Denver’s</a> videos online. In addition, many of the past Atlanta DrupalCamp videos are hosted on the <a href="https://www.mediacurrent.com/resources/videos">Mediacurrent site</a>.</li> </ol> <p>Lastly, here’s a personal tip I offer to all of you that are new. <strong>Get involved in the  Drupal community. </strong>There are hundreds of <a href="http://drupal.meetup.com/">Meetup groups</a>, <a href="http://groups.drupal.org/coworking">Co-working</a> days, <a href="http://buildamodule.com/drupal-camps-calendar">Camps</a>, Cons, (I even heard someone through out a Drupal Paintball day) that you can participate in. Absorbing what others say and listening to experts in the community will grant you a great knowledge of this powerful open source platform.</p> <p>What other tips do you have for those that are new to Drupal? Leave a comment and help us compile a comprehensive list.</p> </div> <span class="field field--name-uid field--type-entity-reference field--label-hidden"><span lang="" about="/about/our-team/adam-waid" typeof="schema:Person" property="schema:name" datatype="">Adam Waid</span></span> <span class="field field--name-created field--type-created field--label-hidden">Thu, 04/12/2012 - 10:26</span> <div class="field field--name-field-tags field--type-entity-reference field--label-above"> <div class="field__label">Tags</div> <div class="field__items"> <div class="field__item"><a href="/tags/development" hreflang="en">Development</a></div> <div class="field__item"><a href="/tags/atlanta-drupal-users-group-meetup" hreflang="en">Atlanta Drupal Users Group Meetup</a></div> <div class="field__item"><a href="/tags/drupal" hreflang="en">Drupal</a></div> <div class="field__item"><a href="/tags/drupal-7" hreflang="en">Drupal 7</a></div> <div class="field__item"><a href="/tags/drupal-community" hreflang="en">Drupal community</a></div> <div class="field__item"><a href="/tags/drupalorg" hreflang="en">Drupal.org</a></div> <div class="field__item"><a href="/tags/drupalcamp" hreflang="en">Drupalcamp</a></div> <div class="field__item"><a href="/tags/drupalcon" hreflang="en">Drupalcon</a></div> <div class="field__item"><a href="/tags/planet-drupal" hreflang="en">Planet Drupal</a></div> <div class="field__item"><a href="/tags/pro-drupal-development" hreflang="en">Pro Drupal Development</a></div> </div> </div> <div class="field field--name-field-related-content field--type-entity-reference field--label-above"> <div class="field__label">Related Content</div> <div class="field__items"> <div class="field__item"><a href="/blog/15-cool-things-you-can-do-drupal" hreflang="en">15 Cool Things You Can Do With Drupal</a></div> </div> </div> <div class="gatsby-iframe-container"><iframe class="gatsby-iframe" src="https://preview-misriptide.gtsb.io/blog/5-tips-drupal-newbies"></iframe></div> Thu, 12 Apr 2012 14:26:15 +0000 Adam Waid 530 at https://publish.mediacurrent.com