# Tuesday, November 11, 2008
Tuesday, November 11, 2008 9:54:02 AM (Eastern Standard Time, UTC-05:00) ( career | languages | programming )

There are several posts (e.g. Joel’s here and Jeremy’s here) about the new SharePoint Master Certification and the debate over it reinforces my decision to stop pursuing SharePoint at the present time. 

So, this blog post is about my brief dive into all that is SharePoint.  A little history:  I became a consultant early last year and one focus was going to be learning SharePoint.  I ended up being assigned to a C++ unmanaged project (a whole different story) and dove into learning C++, MFC, ATL and COM instead.

When I became ATO (at-the office or on-the-bench) this summer, I took the time to pick up SharePoint.  I began attending all of the sessions (at code camps such as CodeStock, devLink, and IndyTechFest) that I could to learn from SharePoint MVPs.  I read many books, listened to podcasts, did hands-on-labs and watched many training webcasts.

Since I have a background in Document Management and Imaging and a huge interest in search, libraries (book kind) and improving user interactions, I really liked what I saw.  I saw SharePoint as a good platform to further my development skills as well as bring the information architecture into the fold.

I studied and passed the Moss application development exam and wrote a few connectible web parts to help out colleagues.   I did not pursue configuration exams since I did not want to be pegged an IT/Infrastructure person (since I’m not).  The more I talked to consultants doing SharePoint locally, the more it became apparent that there is little custom development at the current time (at my employer and location) and that much infrastructure knowledge is needed.  In order to excel at this type of job, I would need to work with an experienced team for some time to develop those skills.  Something a client would not be willing to pay for.

As I love software much more than hardware,  I decided that SharePoint was not where I wanted to be at this time since I would rather be learning advanced development (patterns, AOOP, TDD) and upcoming technologies (WCF, Linq, WF, WPF) with my time.

I am now working for a client on YACPPP (yet another C++ project).  I am just getting started but have been told the code base is well designed in a OOP type of way – so I am anxious to learn how it is architected, see the code  and dive back into C++ (there is much new (for me) to learn in this older technology) .  On the side I am going to learn how to be a better developer in the other areas mentioned.

So SharePoint is out of my thoughts for now, possibly in the future I’ll attack it again when I can from a development angle.  The best part about SharePoint is the community.  I am astonished at the hundreds of SharePoint bloggers working to share what they have learned and the passion I see many have around SharePoint.   All of the SP experts I have met, such as Rob Bogue, Doug Ware, and Rob Foster have been great and  I will keep my eye out on twitter to follow the SharePoint (r) evolution.

maggie++

# Friday, October 17, 2008
Friday, October 17, 2008 9:05:29 AM (Eastern Standard Time, UTC-05:00) ( )
I have gone pink for October here and on twitter to bring attention to Breast Cancer Awareness Month.

Web sites will Go Pink during the month of October to bring attention to Breast Cancer Awareness Month, get people talking about breast cancer, and raise money for research. But to be clear, raising money isn’t the primary purpose of this web event. The hope is that you turn your site pink (in whatever way works for your site), educate yourself about the multiple issues related to Breast Cancer, then take that knowledge and tell someone else what you’ve learned.

Please educate yourself about this important disease.  BreastCancer.org is an excellent place to start.  If you or someone you know are facing breast cancer, check out these forums for support.

maggie++

# Tuesday, October 14, 2008
Tuesday, October 14, 2008 1:38:39 PM (Eastern Standard Time, UTC-05:00) ( career | history | programming )

There are many styles of interviewing software developers.  The best processes are those that allow you to see if the candidate is a good fit for your organization and for the candidate to see if your company is a good fit for them.  Shortcomings on either side can lead to costly mistakes and wasted time on both sides.

When I worked on the GSM switch project at Motorola in the late 80s we spent considerable time recruiting software engineers.  Our process was typically:

  • one engineer would escort candidate from HR to the office area giving a short tour on the way.
  • manager would briefly talk with them and explain the project at a high level and the day’s schedule.
  • depending on candidate’s level and on our availability 2-4 engineers would individually give technical interviews.
  • one interview would include lunch out in a local restaurant.
  • the manager would meet with them again for any follow-up questions and to inquire which part of the system they were interested in before they were escorted back to HR.
This was in addition to the countless hours looking through resumes, phone screen beforehand and HR’s interviews with them before and after ours.

My interview technique was to first have them explain their previous projects and I asked questions where I needed clarification.  Then I would draw a high level architecture diagram of my subsystem and explain how it fit into the product and its purpose.  I would let them lead at this point; I was looking for them to show an interest and curiosity about the system by asking questions and an aptitude for talking about a system from both a high level and a detailed level.  I was looking for inquisitive thinkers who seemed eager to learn and work on a team.

 The candidates did not usually have nor did we expect them to have any telephony experience or knowledge of cellular (analog or digital) phone networks.   Most did not know C or assembler nor had heard about the object oriented concepts we were designing with.  These were important, but at the time software engineering was all about design and process and not at all about the underlying technology.  In fact we did not know ourselves at the beginning if we would be using C++ or C.  Our previous phone switches were coded with assembler.  We ended up using C as the C++ cross-compilers were not proven for our processors at the time and would have been an unnecessary risk.

This process consumed much time but we ended up with an outstanding group of software engineers.

Two podcasts I’ve listened to this past week have had content on more recent interview practices.  First was Episode 16: Interviewing Software Developers from Herding Code.   From the show notes:

This week Kevin leads a discussion on interviewing software developers:

  • What interview styles we find effective
  • What sort of questions actually help us evaluate a candidate
  • Why API trivia and puzzle questions don’t work
  • Hiring mistakes we’ve made based on errors in our interview style
  • Why we don’t do very well when the tables are turned and it’s our turn to be interviewed"
Second one was a podcast featuring Scott Kriens, of Juniper Networks, from Stanford’s Entrepreneurial Thought Leader Speaker Series brought to my attention by Dianne Marsh on twitter.   While the entire talk is not about interviewing there were a few points he made about attracting talent and employee growth that are of interest to the topic.  The first (watch here) encourages developers to embrace challenging interviews and not to let them intimidate you and the second one (watch here) talks about the value of training the employees you have rather than hunting for the one star player.  He states:  “It’s better to give somebody that’s never done something before the chance to do it, then to ask somebody who’s already done it to do it again with energy and enthusiasm. ... There is a real power and passion to prove yourself.  ... They will surprise everyone with their ability to succeed.”

The first one is hard for the candidate and the second is difficult for the employer.   I know times have changed much about the way software is built and funded and a full-day interview would indeed be a luxury and quite costly for all involved.  However getting good thinkers and problem solvers on your team instead of good test-takers is key.  Paying for training and the costs from missed work time can be great but by embracing education as a means to train and retain their developers , companies will see positive results with enhanced productivity and retention.   When growth brings the need for more developers I think an approach that enables both sides to really get a good understanding of each other is prudent.

What techniques do you find useful for finding good developers and what as a developer do you do to find a good employer?  Please leave comments with your ideas or blog about it and comment here so we can learn from each other.

maggie++

# Sunday, September 21, 2008
Sunday, September 21, 2008 3:03:07 PM (Eastern Standard Time, UTC-05:00) ( career | languages | programming )
My first entrance to my programming career is described in How I got started in Programming and leaving to be a full-time SAHM (stay-at-home-mom) in Taking an off-ramp and an on-ramp in IT.  This post will attempt to describe what steps I took to re-enter the workforce.

We were living in Kingsport, TN  in 2001 when I started to think about returning to work.  I felt the first thing I should learn was where the programming profession was;  I knew it had to be radically different from when I left in 1990. At the time I did not know anyone there who worked in software or anything remotely similar.

[2001 -2002] I started a subscription to Dr Dobb's Journal and searched on the internet to find anything I could to learn about software; I did not really know what I was looking for. I joined the internet forum Systers and scoured the library for technical books.  I purchased Microsoft Visual C++ .NET Deluxe Learning Edition and 4 flavors of Java in a NutShell.  I completed the tutorials in both languages.  Additional books I bought and read during this time included:
[2003] We moved to Cincinnati, OH both to live near some family and to obtain better educations for our children.  We wanted our son to attend my husband's alma mater, St Xavier High School, and we wanted choices for my daughter for middle school.  Moving and building a house took most of my energies that first year. I continued to read and search the net and visited the library and read books such as Code Complete, The Mythical Man-Month and a variety of books on Extreme Programming.  I Joined the Cincinnati Programmer's Guild and The Women's Circuit.  I attended meetings for both groups and started to meet "real-live" people that worked in the industry and was exposed to a very wide variety of topics and ideas. 

[ 2004] By 2004 I was starting to gain confidence in my software abilities.  I started looking at job advertisements all over the internet. I determined that there seemed to be more .NET jobs than Java in Cincinnati so I started to narrow in my focus on .NET.  I discovered C# and spent a fortune on books including:
I wanted to take some college or graduate classes but was disappointed to find out that you had to apply for a degree in order to take a class.  I did not want to pursue a degree at that time as I already had a math degree and had completed all of the coursework for a MSCS.  I knew my job search would be difficult considering it had been a very long time since I had been employed and I wanted to prepare myself as best I could. Taking classes was the only way I knew to "prove" on my resume that I had skills. So during the summer I took C# and Relational Databases with SQL classes at the community college.  I really learned nothing new about either C# or relational databases.  The biggest value in the classes was exposure to using Visual Studio and SQL Server software as well as being able to ask questions of the instructors.

I then paid for a week-long training class "Developing Microsoft ASP.NET Web Applications using Visual Studio .NET".  This course was great as it introduced me to ASP.NET, ADO.NET, IIS, Web Forms, Web Applications and XML Web Services and also taught me how to use more features of Visual Studio.  I also learned much from the questions the other students asked as they were all employed and transitioning from asp to ASP.NET programming.

Once the Cincinnati .NET User's Group started in the end of 2004 I began attending and was happy to see many familiar faces from the programmer's guild.

Once I updated my resume with these recent skills I began to see a sharp increase of interest and started going to interviews. The interview
 process is time of growth. I started out extremely nervous but each one got better.  Once I was able to see for myself how many different companies opperated and managed software I knew more about what to ask and what to look for.  I was able to refine my resume, read the job postings with more knowledge and was able to write detailed direct cover letters that got me in the door.  In March of 2005 I started work for a small micro-film/imaging company on a C# Tablet PC application. 

I absolutely loved being back at work. It was a long journey but very much worth the effort.

maggie++

# Wednesday, August 20, 2008
Wednesday, August 20, 2008 8:29:58 PM (Eastern Standard Time, UTC-05:00) ( usability | UX | design )
I learn much from listening to podcasts.  I thought I would share some of my favorite episodes with you from a user experience one that I listen too. SpoolCast is an audio podcast where Jerod Spool from User Interface Engineering interviews experts from all aspects of UX from usability, user testing to research and more.

SpoolCast: Product Evolution with Adaptive Path’s Peter Merholz
July 2nd, 2008

Peter Merholz president of Adaptive Path.  Peter and Jerod discuss a method to map out the evolution of a product into three stages and the importance of planning this at the beginning to continually give the user a good experience while you add features and grow your product.  I learned not to deploy a feature just because it's ready, but to plan the releases so you add features together that make sense without confusing your users while always keeping the business value in the plan. Peter explains a corollary of the release of the ipod in stages.

SpoolCast: Ajax Then and Now with Jeremy Keith  June 16th, 2008

Jeremy Keith is the technical lead at Clearleft, a leading design consultancy in the UK. Jerod and Jeremy discuss Ajax and how it's use in web pages can be useful and where it can hurt.

SpoolCast: What Makes a Great IA with Donna (Maurer) Spencer June 9th, 2008

Donna (Maurer) Spencer, an information architect and owner of the freelance agency MaadMob.  Donna and Jerod discuss what an Information Architect is and what makes a great Information Architect.  They talk of the challenge of architecting the content and the web site navigation so that it makes sense to the end-user and not necessarily model the way the business is organized.  Many clients expect this and each department wants to "tell the world what we do" instead of "make information available in the way people want to read it"

The following two are some basics principles of UI design that are still broken all of the time even though they are difficult for users to use.

Usability Tools Podcast: Applying Fitts’ Law  February 28th, 2008

"A button is a button right? Move the mouse over it. Click. Not much to it, eh?"

Usability Tools Podcast: Mouseovers in Navigation December 17th, 2007

"It’s tempting to spend a ton of time creating slick flyout, dropdown, or pop-up navigation on our site, but is it worth the effort? "

Usability is so important and there is so much research out there about what works and what does not that there is no excuse for developers and designers to continue creating interfaces that are difficult for users to learn and navigate.  I hope more people will take advantage of these podcasts and apply the findings to their design.

maggie++


# Saturday, July 26, 2008
Saturday, July 26, 2008 9:36:35 AM (Eastern Standard Time, UTC-05:00) ( )

A recent addition to my feed list is Managing Product Development  written by Johanna Rothman  founder of a software management consulting and author of Manage It!: Your Guide to Modern, Pragmatic Project Management which is published by the The Pragmatic Programmers .

If you are not subscribed to her blog you are missing out she has great insight into managing software projects.  In her blog I came across an interview she did with Jurgen Appelo posted on his blog here: 5 Easy Questions for Johanna Rothman

The first question was on the toughest challenge in her past.  Se says "Making myself slow down to think through a problem fully." She describes beginning to write a book recently - she started with an outline and began writing then found that her flow was awkward and needed re-work.

When I realized I'd written enough to redesign it, I could see the emergent design. If I'd tried to define the full design for the book at the beginning, it would have been wrong (it was wrong!). Now, I have enough to see how it could work, and my new design is working for now. Who knows, I might have to redesign again. But I know the pieces I have to fit in now

To me this describes a process like code refactoring and helps illustrate why refactoring is so important for software projects. It is difficult to get the design right the first time.  It takes iterations and rework to get it right.  I had never thought that the process of writing a book was was so similar to software development.

 

maggie++

# Sunday, June 29, 2008
Sunday, June 29, 2008 1:16:56 PM (Eastern Standard Time, UTC-05:00) ( browser | flock | social )

Flock, The Social Web Browser!  is a browser I recently discovered that aggregates social networking features into the browser interface.  So far I like what I see.  It is built on top of FireFox 2 and is super simple to set up and use. The description from the user's guide is:
Flock is built on the Mozilla Firefox open-source browser, so it has all the features you've come to expect in a high-quality web browser, like intuitive buttons and menus, personal customizability, reliable security, enhanced privacy protections, and automated updating. However, Flock is much more than that! The Flock Social Web Browser has been fully integrated with a wide range of social networking websites and popular blogging tools. So with Flock, you can now keep in touch and share text, links, pictures, video and more with friends, family and co-workers across the entire internet with unparalleled speed and seamless ease.

Getting Started Video

Side Bars available in addition to firefox's are:
  • Feeds Sidebar is a built-in feed reader.
  • Web Clipboard allows you to drag and drop text, links, and images to save for later use.
  • Accounts and Services gives you access to all of the accounts you have configured with Flock and also lists all supported accounts with links so you can explore them.

My World, is a provided page opened through a tool bar button. It contains columns they call Widgets that currently has 4 functions:

  • Favorite Sites, lists your most recently viewed favorites.
  • Favorite Feeds, displays your feeds with the most recent activity and indicates how many unread items are in the feed.
  • Friend Activity, lists friends updates from you social networks.
  • Favorite Media shows streams from You Tube and Flickr that you subscribe to.

Flock has a Media mini-bar which is like a sidebar except it runs horizontal under the toolbar. This allows easy access to media streams such as Flickr and You Tube. I have hooked up my gmail into flock and am writing this blog entry with tools from Flock to check it out.

There is a Flock 2 Beta available built on top of Firefox 3 that I am going to try soon. 

If you want to see more start out by visiting the Getting Started page and be sure to watch their introduction video here from You Tube.  The videos on the Flock You Tube stream make it very easy to learn about the features; the short movies show the features so that you "get it" quickly instead of reading the manual.

I think as this browsers evolves it will be very useful and replace the use of many different clients that are now needed to access your information.  If you try it leave a comment and let me know what you think.

maggie++



Blogged with the Flock Browser

Tags: , ,

# Monday, June 23, 2008
Monday, June 23, 2008 7:36:49 AM (Eastern Standard Time, UTC-05:00) ( programming | events )

CodeStock's mission is to bring the best and brightest code experts to East Tennessee for a one day conference open to all developers.

Are you among the best and brightest code experts?  If yes, then you are probably already registered.  If not, but you want to be, sign up and join me at CodeStock to learn and keep up with all of the new ways to improve your software skills.

There will be 6 choices of classes during each session and what I'm excited about is there will be Open Spaces all day where you can share and learn about whatever you are interested in. 

Open Space is a way to bring together groups of people interested in a common topic to have an interactive discussion. In an Open Space session, there may be an expert who is passionate about a topic presenting to an audience or there may be a small group of people discussing an idea.

Four principles of Open Space:

  1. Whoever comes are the right people to be there
  2. Whatever happens is the only thing that could have happened
  3. Whenever it starts is the right time
  4. When it's over, it's over

This is my kind of conference - a place where I can learn from other developers in a relaxed setting in beautiful Tennessee.  

Hope to meet you there.

maggie++