Collaborative Software Design & Development Open Source Systems 4

Total Page:16

File Type:pdf, Size:1020Kb

Collaborative Software Design & Development Open Source Systems 4 Collaborative Software Design and Development Open Source Systems 4 Collaborative Software Design & Development Open Source Systems 4 The FreeBSD Project Apache Field Support Kyle Cullen and Sabrina Smith 2/21/08 © 2006, Dewayne E Perry EE 382V – Spring 08 1 Collaborative Software Design and Development Open Source Systems 4 The papers we’ll be covering: The FreeBSD Project: A Replication Case Study of Open Source Development Trung T. Dinh-Trong - Research scientist at Avaya Labs James M. Bieman - Professor at Colorado State University and Director of the Software Assurance Laboratory How open source software works: “free” user-to-user assistance Karim R. Lakhani - Assistant professor in the Technology and Operations Management Unit at Harvard Business School Eric von Hippel - Professor at the MIT Sloan School of Management and Head of the Innovation and Entrepreneurship Group © 2006, Dewayne E Perry EE 382V – Spring 08 2 Collaborative Software Design and Development Open Source Systems 4 Advantages / Disadvantages Advantages Freedom to work on whatever you want The review of others’ works could potentially lead to an increase in your overall software development skill level You can work at your own pace – no deadlines Disadvantages Lack of formal process Poor design and architecture Lack of development tools that are comparable to closed-source industry tools Lack of knowledge of the users’ needs © 2006, Dewayne E Perry EE 382V – Spring 08 3 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Main Idea A study of FreeBSD to determine contributing factors to successful OSS projects Characteristics of previously successful OSS projects Not guaranteed to be necessary or sufficient to future successful OSS projects How? Do the 7 hypotheses presented by Mockus et al. in “Two Case Studies of Open Source Software Development: Apache and Mozilla” hold up for other projects? Specifically, FreeBSD © 2006, Dewayne E Perry EE 382V – Spring 08 4 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Data Sources Email, Bug Reports, and CVS Java program used to search through these data sources and extract relevant information the number of committers the number of deltas committed by each person etc. Questionnaire sent to each of the FreeBSD core developers © 2006, Dewayne E Perry EE 382V – Spring 08 5 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Questionnaire Question 1: “What was the process used to develop FreeBSD?” Roles of FreeBSD participants core developers – a small group of senior developers who are responsible for deciding the overall goals and direction of the project committers – developers who have the authority to commit changes to the project CVS repository contributors – people who want to contribute to the project but do not have committer privileges How do individuals identify what they will work on? contributors do what is interesting come up with new feature fix a bug you have found search through list of current bugs and desired features core developers do the rest (mundane tasks, etc.) © 2006, Dewayne E Perry EE 382V – Spring 08 6 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Questionnaire Question 1: “What was the process used to develop FreeBSD?” cont. Code Release Deadlines 45 days – integration notifications sent out (15 days left!) 30 days – peer reviews and last minute bug fixes 15 days – code freeze and weekly distributions start (beta versions) 0 days – final release © 2006, Dewayne E Perry EE 382V – Spring 08 7 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Questionnaire Question 2: “How many people wrote code for new functionality? How many people reported problems? How many people repaired defects?” 354 committers added code between 1933 and April 2003 337 committers checked in new features 6082+ unique individuals reported problems 224 committers fixed problems © 2006, Dewayne E Perry EE 382V – Spring 08 8 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Questionnaire Question 3: “Were these functions carried out by distinct groups of people, that is, did people primarily assume a single role? Did large numbers of people participate somewhat equally in these activities, or did a small number of people do most of the work?” 220/354 did both bug fixing and new feature development 47 committers contributed 80% of the deltas End result: a lot more top committers in FreeBSD than in Apache © 2006, Dewayne E Perry EE 382V – Spring 08 9 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Questionnaire Question 4: “Where did the code contributors work in the code? Was strict code ownership enforced on a file or module level?” Contributors were free to work on all parts of code – ownership was not enforced 30% of files were only changed by one developer © 2006, Dewayne E Perry EE 382V – Spring 08 10 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: Questionnaire Question 5: “What is the defect density of FreeBSD code?” Defect density is similar to that of Apache, and is lower than commercial products. © 2006, Dewayne E Perry EE 382V – Spring 08 11 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: H1 “Open source developments will have a core of developers who control the code base, and will create approximately 80 percent or more of the new functionality. If this core group uses only informal ad hoc means of coordinating their work, the group will be no larger than 10 to 15 people.” Core group for FreeBSD consisted of 36 people Core group for FreeBSD only wrote 47% of code Edited hypothesis: Core developers (< 15) will control the direction of the project while a larger group of top developers (< 50) will contribute approximately 80% of the code base, and their sum is less than 25% of all developers. Spirit of this edited hypothesis matches the spirit of the original one, so hypothesis is confirmed © 2006, Dewayne E Perry EE 382V – Spring 08 12 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: H2 “If a project is so large that more than 10 to 15 people are required to complete 80 percent of the code in the desired time frame, then other mechanisms, rather than just informal ad hoc arrangements, will be required in order to coordinate the work. These mechanisms may include one or more of the following: explicit development processes, individual or group code ownership, and required inspections.” The high number of top committers in FreeBSD required more mechanisms for coordinating work than were needed in Apache; however, these methods were informal and not enforced. H2 should be edited to suggest that more mechanisms are needed, but they don’t need to be formal. © 2006, Dewayne E Perry EE 382V – Spring 08 13 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: H3 “In successful open source developments, a group larger by an order of magnitude than the core will repair defects, and a yet larger group (by another order of magnitude) will report problems.” This hypothesis holds for FreeBSD. Could other organizational structures also work? Is a good organizational structure necessary for success? © 2006, Dewayne E Perry EE 382V – Spring 08 14 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: H4 “Open source developments that have a strong core of developers but never achieve large numbers of contributors beyond that core will be able to create new functionality but will fail because of a lack of resources devoted to finding and repairing defects.” FreeBSD had many contributors, so H4 could not be evaluated. © 2006, Dewayne E Perry EE 382V – Spring 08 15 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: H5 “Defect density in open source releases will generally be lower than commercial code that has only been feature-tested, that is, received a comparable level of testing.” FreeBSD supports this hypothesis. This hypothesis refers to unstable OSS releases (those that have only been feature-tested), so the authors extend the hypothesis to include stable releases as follows: “Defect density in OSS releases will be lower than commercial code that has only been feature-tested. If an OSS has a mechanism to separate unstable code from stable code or “official” releases, then the defect density of the stable code releases will be equivalent to that of commercial code after release.” © 2006, Dewayne E Perry EE 382V – Spring 08 16 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: H6 “In successful open source developments, the developers will also be users of the software.” Developers of FreeBSD were also users, so H6 holds true. Can OSS developers who are not users be successful if they listen carefully to user feedback, i.e. is it necessary for OSS developers to also be users? © 2006, Dewayne E Perry EE 382V – Spring 08 17 Collaborative Software Design and Development Open Source Systems 4 The FreeBSD Project: H7 “OSS developments exhibit very rapid responses to customer problems.” The authors didn’t have access to data about the responsiveness of FreeBSD developments to customer problems, so H7 could not
Recommended publications
  • A Survey of Collaborative Tools in Software Development
    1 INTRODUCTION A Survey of Collaborative Tools in Software Development Anita Sarma Institute for Software Research Donald Bren School of Information and Computer Sciences University of California, Irvine [email protected] ISR Technical Report # UCI-ISR-05-3 March 22, 2005 1 Introduction Collaboration is at the heart of software development. Virtually all software devel- opment requires collaboration among developers within and outside their project teams, to achieve a common objective. It has in fact been shown that about 70% of a software engineer’s time is spent on collaborative activities [219]. Indeed, col- laboration in software development has been studied by researchers in the fields of Software Engineering and Computer Supported Cooperative Work (CSCW) since the 1980s and has produced a wide range of collaborative tools. Enabling software developers to collaborate effectively and effortlessly is a difficult task. The collaboration needs of the team depend to a large extent on environmental factors such as, the organizational structure of the team, the domain for which the software is produced, the product structure, and individual team members. Accordingly, research in collaborative development has produced a host of tools, each typically focussing on a different aspect of collaboration. Most teams have their favorite repertoire of tools that has been built from historical use. These tools may not always be the best suited for the team, but the team still uses them nevertheless as the inertia and cost of trying out new tools surpasses the benefits. A number of classification frameworks exist that can be used to classify collaborative tools. In addition to placing the various tools in context, developers can use these frameworks to select the right mix of tools fit for their needs.
    [Show full text]
  • Collaborative Education in a Virtual Learning Environment Hani Bani
    Collaborative Education in a Virtual Learning Environment Hani Bani-Salameh Department of Software Engineering, The Hashemite University, Zarqa 13115, Jordan E-mail: [email protected] Jafar Al-Gharaibeh Architecture Technology Corporation, Eden Prairie, MN 55344, United States E-mail: [email protected] Clinton Jeffery Department of Computer Science, University of Idaho, Moscow, ID 83843, USA E-mail: [email protected] Ziad A. Al-Sharif Department of Software Engineering, Jordan University of Sci. & Tech, Irbid, Jordan E-mail: [email protected] Abstract: For the last few decades, there was tremendous interest in harnessing 3D virtual environments for education and training. Multi-user game-like environments make use of non-player characters and quest activities in tutoring and training. This approach incorporates successful active learning and incremental progress. This article presents issues encountered while adapting the multi-user online game genre for educational virtual environments. In this endeavour, non-player characters play a central role in organizing and delivering educational content. Educational virtual environments call for additional kinds of extension beyond generic user content creation as delivered in some virtual worlds like SecondLife. Support for these environments will emphasize the creation of new activities. A set of libraries and techniques named Portable Non-player character tutors and Quests reduces the effort needed to develop and integrate educational non-player characters. These non-player characters are introduced in CVE, a platform for rapidly developing educational virtual environments. The Portable Non-player character tutors and Quests framework enables formatted web-based exercises, quizzes, and educational content to be incorporated into Copyright © 2016 Inderscience Enterprises Ltd.
    [Show full text]
  • Invisible Crowds in Cyberspace
    Invisible Crowds in Cyberspace: Mapping the Social Structure of the Usenet1 Marc A. Smith University of California, Los Angeles Published in: Smith, Marc. “Invisible Crowds in Cyberspace: Measuring and Mapping the Social Structure of USENET” in Communities in Cyberspace: Perspectives on New Forms of Social Organization.. London, Routledge Press, 1999 SURVEYING SOCIAL CYBERSPACES The Usenet is a quintessential Internet social phenomenon: it is huge, global, anarchic and rapidly growing. It is also mostly invisible. Although, it is the largest example of a conferencing or discussion group system,2 the tools generally available to access it only display leaves and branches - chains of messages and responses. None present the trees and forest. With hundreds of thousands of new messages every day, it is impossible to try to read them all to get a sense of the entire place. As a result, an overview of activity in the Usenet has been difficult to assemble and many basic questions about its size, shape, structure and dynamics have gone unanswered. How big is the Usenet? How many people post? Where are they from? When and where do they post? How do groups vary from one another and over time? How many different kinds of groups are there? How many groups successfully thrive and how many die? What do the survivors have that the others lack? How do different social cyberspaces connect and fit together and form a larger ecology? There is no shortage of questions. But we lack a historical record of the transformations of social cyberspaces3 just at the point when network interaction media are being widely adopted.
    [Show full text]
  • Adopting a Collaborative Software Development Process in the Scientific Community
    Adopting a Collaborative Software Development Process in the Scientific Community NOAA's 32nd Climate Diagnostics and Prediction Workshop (CDPW) Mike Charles DOC/NOAA/NWS/NCEP/CPC Motivation To advocate improved software development and project management techniques, including collaborative software development and the use of project management software. Who does this apply to? • Universities • Government • Private sector • Any software developers From now on, for the sake of brevity, "collaborative work" will include use of project management software. Disadvantages of Non- Collaborative Work Non-Collaborative Work A developer works alone • Work goes unchecked by others • If the owner leaves, nobody knows how the software works • There are no ideas contributed by others during development Non-Collaborative Work A developer doesn't log changes • Hard to revert to a previous version of the code • Can't remember what they did last week • Can't tell why a specific change was made Non-Collaborative Work A developer doesn't create documentation • Hard for others to adopt code • Hard for backup code owners to fix bugs and/or run code • Hard to share code with others Advantages of Collaborative Work Collaborative Work How should developers be working? • Collaboration - Working with others leads to more ideas and creativity, and more QCing of code • Tracking Changes - Using revision control software, tracking changes to code and keeping a log makes it easier to revert to older versions of the code, and keep track of work • Documentation - Creating
    [Show full text]
  • WHY USE a WIKI? an Introduction to the Latest Online Publishing Format
    WHY USE A WIKI? An Introduction to the Latest Online Publishing Format A WebWorks.com White Paper Author: Alan J. Porter VP-Operations WebWorks.com a brand of Quadralay Corporation [email protected] WW_WP0309_WIKIpub © 2009 – Quadralay Corporation. All rights reserved. NOTE: Please feel free to redistribute this white paper to anyone you feel may benefit. If you would like an electronic copy for distribution, just send an e-mail to [email protected] CONTENTS Overview................................................................................................................................ 2 What is a Wiki? ...................................................................................................................... 2 Open Editing = Collaborative Authoring .................................................................................. 3 Wikis in More Detail................................................................................................................ 3 Wikis Are Everywhere ............................................................................................................ 4 Why Use a Wiki...................................................................................................................... 5 Getting People to Use Wikis ................................................................................................... 8 Populating the Wiki................................................................................................................. 9 WebWorks ePublisher and Wikis
    [Show full text]
  • Collaborative Software Performance Engineering for Enterprise Applications
    Proceedings of the 50th Hawaii International Conference on System Sciences | 2017 Collaborative Software Performance Engineering for Enterprise Applications Hendrik Müller, Sascha Bosse, Markus Wirth, Klaus Turowski Faculty of Computer Science, Otto-von-Guericke-University, Magdeburg, Germany {hendrik.mueller, sascha.bosse, markus.wirth, klaus.turowski}@ovgu.de Abstract address these challenges from a software engineering perspective under the term DevOps [2], [3]. In the domain of enterprise applications, Corresponding research activities aim at increased organizations usually implement third-party standard flexibility through shorter release cycles in order to software components in order to save costs. Hence, support frequently changing business processes. application performance monitoring activities Therefore, DevOps enables a culture, practices and constantly produce log entries that are comparable to automation that support fast, efficient and reliable a certain extent, holding the potential for valuable software delivery [4]. However, especially for collaboration across organizational borders. Taking enterprise applications, IT departments usually make advantage of this fact, we propose a collaborative use of existing standard software components instead knowledge base, aimed to support decisions of of developing solutions entirely in-house [5]. In such performance engineering activities, carried out cases, activities referred to as Dev, rather include during early design phases of planned enterprise requirements engineering, architectural design, applications. To verify our assumption of cross- customization, testing, performance-tuning and organizational comparability, machine learning deployment [6]. Here, key service levels typically algorithms were trained on monitoring logs of 18,927 include performance objectives, expressed in terms of standard application instances productively running average response times, throughput or latency, in at different organizations around the globe.
    [Show full text]
  • Personalizing the Collaborative Learning Environment with Pictures
    Personalizing the Collaborative Learning Environment with Pictures Brian Mackie OMIS Department, Northern Illinois University DeKalb, IL 60115, USA [email protected] and Charletta F. Gutierrez ABF Department, Northeastern Illinois University 5500 N. St. Louis Avenue Chicago, IL 60625, USA [email protected] ABSTRACT that are geographically and time-dispersed [3]. Making the most efficient use of time is critical in today’s fast-paced world. The Internet and Web-based technologies, as well as rapid Collaborative software can expedite the ability of groups to globalization, are changing the way businesses communicate. develop a shared understanding of a problem or task and move Continuous progress in Information Technology (IT) enables towards a solution. According to [4], new technology should be effective and efficient communication, particularly with the use developed in such a way that it enhances the existing culture. of collaborative systems. Such systems have many different That is, such technology should be developed from within the types of interfaces and attributes, and one such attribute is the use organization, rather than being pushed down from upper of visuals. This research assesses the usefulness of participant management [4]. Technologies should not just adapt to the pictures in a collaborative exchange. To evaluate the usefulness existing culture, but should help the organization change the of such pictures, participants were asked a series of questions existing norms; otherwise such technologies are likely to fail regarding the use of pictures in CAMS, a collaborative [5],[6]. To be effective, these technologies must do more than environment. The results suggest that, in a collaborative setting, automate existing practices; they should improve processes not the use of pictures is valuable in enhancing a “sense of only in the business organization but also in educational settings community,” particularly in cases where participants have not [6],[7].
    [Show full text]
  • Wikis As a Tool for Collaborative Language Learning: Implications for Literacy, Language Education and Multilingualism
    ISSN 2335-2019 (Print), ISSN 2335-2027 (Online) Darnioji daugiakalbystė | Sustainable Multilingualism | 5/2014 http://dx.doi.org/10.7220/2335-2027.5.8 Selami Aydin Balikesir University, Turkey WIKIS AS A TOOL FOR COLLABORATIVE LANGUAGE LEARNING: IMPLICATIONS FOR LITERACY, LANGUAGE EDUCATION AND MULTILINGUALISM Summary. This study presents a review of the literature concerning the use of wikis as a tool for collaborative learning in the second language acquisition and foreign language learning process, as research on the use of wikis is relatively new. The study first introduces the theoretical background behind the use of wikis in the mentioned processes. Then, it reviews the studies concerning wikis as a tool for collaborative language learning. The study concludes that the use of wikis improves basic language skills, encourages positive perceptions of learning, increases motivation, provides opportunities to practice autonomy, and enhances inquiry learning and critical thinking, although they appear to have no effect on cultural proficiency. More importantly, Wikis appear to be an advantageous tool for improving writing, and may have additional benefits in developing literacy in multilingual contexts where access to minor languages in the educational process is limited. The paper ends with practical recommendations for teachers and researchers. Keywords: collaborative learning; collaboration; foreign language learning; learner autonomy; second language learning. Introduction Within the contexts of second language acquisition and foreign language learning, wikis constitute a quickly emerging and popular learning tool. Because research on their efficiency is relatively new, wikis’ efficacy in the language acquisition and learning processes remains an open question. This study aims to review various scientific studies on the use of wikis as a tool for collaborative learning and their role within second language acquisition and foreign language learning contexts.
    [Show full text]
  • Enterprise Collaboration & Social Software
    Enterprise Collaboration & Social Software June 2013 INDUSTRY REPORT INSIDE THIS ISSUE Enterprise Collaboration & Social Software 1. Introduction INTRODUCTION 2. Market Trends This report focuses on technologies for collaboration and socialization within the enterprise. A number of forces are currently playing out in the enterprise IT 3. Competitive Landscape environment that are creating an inflection in the adoption and deployment of social and collaboration technologies. This significant uptrend has provided strong 4. M&A Activity growth for the sector and is driving a substantial amount of M&A and investment activity. This report includes a review of the recent M&A and private investing 5. Private Financings activities in enterprise social and collaboration software, particularly within the areas of group collaboration & workspaces, private social platforms, project and 6. Valution Trends social task management, event scheduling, web collaboration, white boarding & diagramming, and other related technologies. We have also profiled about 50 emerging private players in these subcategories to provide an overview of the 7. Emerging Private Companies breadth and diversity of the players targeting this sector. OVERVIEW Socialization and collaboration technologies are currently reshaping the established enterprise collaboration market as well as creating whole new categories of offerings, especially around private social platforms. In addition, many other enterprise applications such as CRM and unified communications are heavily transformed through the incorporation of new technologies including group messaging & activity feeds, document collaboration, and analytics. Much of this change is being driven by the consumerization of IT and the incorporation of social technologies. As businesses look to leverage the benefits of improved “connecting” and “network building” that employees have experienced with Facebook and other social solutions, a convergence is occurring between the enterprise social software and collaboration markets.
    [Show full text]
  • The Dos and Don'ts of Videoconferencing in Higher
    The Dos and Don’ts of Videoconferencing in Higher Education HUSAT Research Institute Loughborough University of Technology Lindsey Butters Anne Clarke Tim Hewson Sue Pomfrett Contents Acknowledgements .................................................................................................................1 Introduction .............................................................................................................................3 How to use this report ..............................................................................................................3 Chapter 1 Videoconferencing in Higher Education — How to get it right ...................................5 Structure of this chapter ...............................................................................................5 Part 1 — Subject sections ............................................................................................6 Uses of videoconferencing, videoconferencing systems, the environment, funding, management Part 2 — Where are you now? ......................................................................................17 Guidance to individual users or service providers Chapter 2 Videoconferencing Services — What is Available .....................................................30 Structure of this chapter ...............................................................................................30 Overview of currently available services .......................................................................30 Broadcasting
    [Show full text]
  • The Role of Collaborative Software and Decision Support Systems in the Smarter Cities
    View metadata, citation and similar papers at core.ac.uk brought to you by CORE provided by Research Papers in Economics THE ROLE OF COLLABORATIVE SOFTWARE AND DECISION SUPPORT SYSTEMS IN THE SMARTER CITIES Virgil Chichernea1 Abstract The transition from the traditional city to the smart city is made by supported efforts regarding the achievement of a more steady, more efficient, more responsible city, through convergent strategies that deal with Smart Transportation Systems, Energy and Utilities Management, Water Management, Smart Public Safety, Healthcare Systems, Environmental Management, Educational Systems, Telecommunications (ITC Support),etc. and Positive Thinking. Service Oriented Architecture (SOA) meets the customers’ needs and the administration, the management of data, information, knowledge and decisions through Collaborative Systems and Decision Support Systems have a major impact both at the level of the smart city and the level of subsystems/services, and the information technology within smart cities becomes a major direction of research in the field of ITC. Keywords: Smart City, Collaborative Systems, Decision Support Systems (DSS), Service Oriented Architecture (SOA), Portal technology Introduction: Collaborative software (also referred to as groupware, workgroup support systems or simply group support systems) is computer software designed to help people involved in a common task achieve their goals. It is usually associated with individuals not physically co-located, but instead working together across an internet connection. It can also include remote access storage systems for archiving common use data files that can be accessed, modified and retrieved by the distributed workgroup members. Collaborative software is a broad concept that greatly overlaps with Computer-supported cooperative work (CSCW).
    [Show full text]
  • Introducing Social Development Environments
    INTRODUCING SOCIAL DEVELOPMENT ENVIRONMENTS Hani Bani-Salameh Clinton Jeffery Iyad Abu Doush Computer Science Department Computer Science Department Computer Science Department University of Idaho University of Idaho Yarmouk University Moscow, ID 83843, USA Moscow, ID 83843, USA Irbid, Jordan [email protected] [email protected] [email protected] “CDEs are essentially team centric, meaning that their primary user experience focuses on the needs of the team (but with points ABSTRACT of entry for different individuals).” A Social Development Environment is a real-time collaborative programming tool with integrated social networking features. Grady Booch [1, 5] stated that the purpose of a CDE is to This emerging technology is important for distributed software create a foundation for environments (tools) that reduces the developers, e-learning and technical communities. Social frictions that have an impact on the daily work of the distributed Development Environments advance the state of the art for software developers and reduces both individual and group collaboration, coordination, and project management in software efficiency, and to support the development process during the development. whole life cycle of the project. Social Development Environments provide a wide range of In contrast with the support that CDEs provide for teams facilities for synchronous and asynchronous collaboration and working closely together, social networks build online information sharing between team members. This paper provides communities of people loosely connected by their common an overview of SDEs and compares state of the art examples with interests or activities. Community is a vital aspect of software our novel solution called SCI (Social Collaborative IDE).
    [Show full text]