Stojanov ICTSME2011

Download as pdf or txt
Download as pdf or txt
You are on page 1of 7

See discussions, stats, and author profiles for this publication at: https://www.researchgate.

net/publication/272292082

Software maintenance support activities: Challenges for very small software


companies

Conference Paper · September 2011

CITATION READS

1 11,023

1 author:

Zeljko Stojanov
University of Novi Sad
81 PUBLICATIONS 390 CITATIONS

SEE PROFILE

All content following this page was uploaded by Zeljko Stojanov on 15 February 2015.

The user has requested enhancement of the downloaded file.


Software maintenance support activities:
Challenges for very small software companies
Z. Stojanov*
* University of Novi Sad, Technical Faculty “Mihajlo Pupin”, Zreanjanin, Serbia

[email protected]

Abstract – Software maintenance is a set of activities should be seriously considered because the maintenance
performed in order to ensure proper functioning of software costs can be several times higher than the costs during the
systems. Maintenance activities are event driven and usually development, especially for product with long life [6]. In
are initiated by customers. Maintenance support or front- literature can be found that maintenance costs are between
end maintenance activities are activities that provide direct 40% and 90% of whole costs in software life cycle.
contact to customers, and therefore are very important for Despite that fact, software maintenance is in literature
business success of software companies. These activities in considered as the last phase in software life cycle with
some cases require execution of back-end maintenance
little attention comparing to software development. The
processes that are realized on software products. Because of
consequence is that maintained software contains more
specific organization of small software companies, and
identified problems in their business, support activities play
errors than initially delivered software [7].
important role for their success in market. In this paper are There are many reasons for software maintenance
outlined some challenges for very small software companies activities, but generally, software maintenance tasks are
in the field of software maintenance support. more complex then tasks during software development.
The reasons for that are [7]:
I. INTRODUCTION • Documentation does not exist, or it is poor (major
Maintenance technologies supported with information cause of distrust of the documentation by
technologies (IT) emerged 40 years ago [1]. Published engineers in maintenance [8]).
research results revealed that maintenance has great • Difficulties in understanding code written by
impact on business performance such as productivity and someone else.
profitability [2][3]. Implementation of effective
maintenance procedures and strategies can significantly • Programmers that develop software usually are
reduce problems that occur during system usage. In the not available to answer questions about software.
context of engineering, maintenance has a wide range of Programmers are unavailable or they cannot be
meanings and includes all actions related to preserving identified [9][10].
consistency and efficiency of complex systems [4].
Cigolini et al. stated [4]: “The scope of maintenance has • Software is not designed to be easily modified.
grown to include not only system repair, but also system • Maintenance is less attractive than development.
safety, economic viability, quality, and the most Maintenance tasks are often avoided in practice
appropriate use of environmental resources.” [11], or are consider to be intellectually boring
Software maintenance is generally defined as any and tedious [12]
work performed on software system that is operational The main difference between software development
and used by customers. Parikh provide the most and maintenance is that development is requirement-
comprehensive definition of software maintenance [5]: driven and maintenance is event-driven [13]. This means
“Software maintenance is the work done on a software that maintenance activities are unscheduled or random
system after it becomes operational. It includes: events initiated mostly by customers, but also can be
understanding and documenting existing systems; initiated by maintenance human resource (engineers or
extending existing functions; adding new functions; managers) or even by market.
finding and correcting bugs; answering questions for
users and operations staff; training new systems staff; Software maintenance activities are usually triggered
rewriting, restructuring, converting and purging software; by customers (software end users), and therefore software
managing the software of an operational system; and companies should provide efficient support services that
many other activities that go into running a successful will help in solving customer requests. The first contact
software system.” with customer is handled by operative support that assists
customer in submitting requests. This operative support is
The maintenance phase of software life cycle begins in practice realized as font-end support that can be
after development and delivery of a software product, independent organizational unit in a software company or
although some maintenance activities can be performed is integrated into other organizational units (maintenance
also during software development. Software maintenance unit, development unit). Nevertheless, maintenance front-
end support requires more research, especially in small may require a broad understanding of a large part of the
software companies that have specific organization and product (its architecture) and various technologies used
usually do not have organizational units dedicated to during development [8].
specific activities.
The most common activities in maintenance are
The rest of the paper is structured as follows. In the modification activities that are, further, divided into:
second section are outlined maintenance activities, while corrections and enhancements. Both, corrections and
in the third section are outlined basic concepts of enhancements change software systems, but it is very
maintenance support and support activities. After that are important to clearly distinguish between them because
outlined maintenance support challenges for very small they are differently observed from the financial point of
software companies, and some concluding remarks. view. In practice, corrections are in many cases free of
charge to users, while enhancements are charged to users
II. SOFTWARE MAINTENANCE ACTIVITIES because they include new development and require
understanding of the whole software product.
Software maintenance includes short-term activities
(e.g., fixing critical problems) as well as long-term Maintenance activities can be also classified according
activities (e.g., a major enhancement to an existing system to various levels of granularity, including the line of code
that result in new version of existing system or in level, change-log level, module level, and program level
completely new software system) [14]. Nevertheless, the [15]. Various granularity levels require different skills and
maintenance is generally viewed as a collection of short- knowledge, different tools and techniques. For example,
term activities. change activity at the level of the lines of code requires
knowledge and skills in appropriate programming
Ontology of maintenance activities is presented in language, and usage of tools that help in finding the
[13]. Definitions of the elements in the ontology are given difference between versions of source code files (for
in Table I. Different maintenance activities require example differences in the code can be found with diff
different tools and techniques, and also different skills and utility that is integrated in many modern development
knowledge for maintainers. For example, different environments). At the other hand, maintenance activities
knowledge is necessary for analyzing customer problem at module level, or program level requires additional
reports and for providing training to customers. In knowledge about software architecture, requires usage of
practice, training for software system usage do not require advanced modeling tools (UML modeling, conceptual
knowledge about source code or deeper knowledge about modeling, XML modeling), and requires the knowledge of
the software architecture, while this knowledge is various technologies.
necessary for solving reported problems that require
interventions on the software system. Further, corrective Findings of empirical study about the factors which
determinate maintenance activities [16], showed that there
exist predictable maintenance patterns for the business
TABLE I. MAINTENANCE ACTIVITY ONTOLOGY DEFINITIONS [13]
software systems. These results confirmed that usage of
appropriate management and planning methods can
Activity An action of one of the following types: an improve various maintenance activities, and even reduce
investigation activity, a modification activity, a them.
management activity, or a quality assurance
activity. An activity may be made up of a Four processes that pertain to the quality of software
number of sub- activities. Usually, it takes as
maintenance are [17]:
input one, or more existing artifacts and
outputs zero, one or many new or modified • Translate customer expectations with respect to
artifacts.
Investigation An activity that assesses the impact of
maintenance into clear service agreements.
activity undertaking a modification arising from a • Use these service agreements as a basis for
change request or problem report.
Modification An activity that takes one or more input planning and implementing maintenance
activity artefacts and produces one or more output activities.
artefacts that, when incorporated into an
existing system, change its behaviour or • Ensure that maintenance is done according to
implementation. planning and procedures.
Management An activity related to the management of the
activity maintenance process or to the configuration • Manage the internal (in software company) end
control of the maintained product. external (with customers) communication about
Quality An activity aimed at ensuring that a the maintenance activities carried out.
assurance modification activity does not damage the
activity integrity of the product being maintained.
Quality assurance activities may be classified III. SOFTWARE MAINTENANCE SUPPORT ACTIVITIES
as testing or certification activities.
Resource Everything that is used to perform an activity.
The business in many organizations is highly
Resources may be hardware, software or dependent of IT and, therefore these organizations need
human resources. various kind of support during the operation and the
exploitation of their IT systems. The most of the costs
related to IT are IT services costs that consist of the costs
activities may require only the ability to locate faulty code of integration, operation and exploitation of IT systems
and make local changes, while an enhancement activity [18]. These IT services include performance and
availability support, end-user and help desk support, At this level are placed activities such as consultation,
education, and technical operation. In practice, there is help desk, education and training, problem and requests
still a lack of formal and structured customer orientation elicitation, and delivery of solutions to customers. In some
in IT Service Management, which is also reflected on cases, companies at this level organize help desk [24], or
software maintenance support services. One possible software hot lines [25]. Personnel at this level have
solution for this problem is usage of Service Level general knowledge about software and required IT
Agreement (SLA) as an instrument for the management of infrastructure for its proper functioning. More complex
the customer's expectations [17][18]. This implies that problems or requests that require deeper understanding of
software maintenance support can be seen as providing software product are forwarded to back-end support level.
services to customers.
A quick and accurate response and support to
customers’ requests ensures their satisfaction and TABLE II. TYPES OF FRONT-END SUPPORT ACTIVITIES [21]
increases the quality of provided services. This support
primarily depends on experience and skills of support Software problem management
Testing
personnel [19]. The beneficiaries of the efficient support
Participate in change management process
are both customers and organization that provides support
Quality Control
(customer support people and mangers). Consultation
In software companies, support activities are part of Technical Support
front-end support, or upfront maintenance. These Education and Training of customers
activities are oriented towards customers to assist them in Self-education and training
the operation of their software and/or integrated software Preventive maintenance
and hardware products [20]. This support is focused on Passive Requirements Elicitation
Active Requirements Elicitation
providing immediate help to customers when they
Monitoring the process
encounter problems or difficulties that prevent them from Measure customer satisfaction
conducting their daily business. Managing emergency cases
In practice, front-end support activities vary from Managing disaster recovery
technical support, to participation in testing, quality Manage customer profile
auditioning, education and training, handling of
emergency cases to management of customer profiles.
Knowledge is crucial for software support, because
These support activities are more or less integrated or
solving specific problems require understanding of
related to the evolution and maintenance work. For
specific details relevant for that problem. These relevant
example solving reported problem is closely related to
details come in many different kinds [25]: details about
evolution and maintenance, while providing training about
software product (features, known bugs, etc.), details
newly integrated feature in a software product is not
about the hardware (disk drives, monitors, networks, etc.),
related to maintenance work. Each software company
details about compatibility with other software (business
provides a set of support activities. The list of empirically
information systems, operating systems,
identified types of support activities is presented in Table
telecommunications, etc.) and so on. Further knowledge
II [21].
that is necessary part of software support is related to
The most common constellation of support levels in details about customer’s business and their hardware and
organizations that provide software maintenance support
is presented in Figure 1. This organization is based on Customer business processes
research reported in [20][22]. In many software
companies do not exists all these levels. Each software Customer
company tailors support activities according to available
Support and Deliver solution to
resources. maintenance requests customer
At customer level are executed customer business
processes supported by various software products. At this
Front-end support processes
level customer identified problems or require new features
Software company

in existing software products, report requests to a software Front-end support


company, and later helps in integrating new solutions in
Transfer requests that
their business environment. require modification of Deliver solution
Front-end support level is primarily engaged in software
providing a continuous feedback to customers. The most
of the working time support people spent in interactions Back-end maintenance processes
with customers. Personnel at this level collect requests
from customers, do the preliminary analyses and solve all Back-end support
requests that are in their domain of expertise. During the
work, support personnel require help, and they find it in
Figure 1. Organization of support levels in software companies
documentation, database, ask their colleagues (from front-
end or back-end level), or even ask customers [23].
software infrastructure. All this details are important for The main challenges posed to software VSEs are [28]:
proper interpretation of problems identified by customer. managing and improving their software processes, dealing
with rapid technology advances, maintaining their
Mastery of technical details is not enough for effective products, operating in a global software environment, and
software support [25]. Social skills are also very important sustaining their organizations through growth. Empirical
for personnel in software support. They should possess evidence presented in [35] suggests that software VSEs
pragmatic reasoning in all situations, they must be able to should combine high level of customer orientation, with
discern customers’ needs and hopefully, meet them, and high levels of entrepreneurial and technology orientations.
they must be able to put some distance between Hakala and Kohtamäki reported that 67% of software
themselves and their work and not take things too companies provide various maintenance or user support
personally. Typical situation when social skills are very services.
important are when user makes “stupid mistake” and
report serious problem with software, or when user that Challenges identified in [28] can be applied also to
reports problem is angry. software maintenance support activities. Because of the
importance and great cost of maintenance activities, there
Software front-end support requires service from back- is a need to investigate them in more details. Regarding
end support when support personnel cannot solve identified problems within front-end support in [20] the
technical problem or request reported by customers. In following challenges for software VSEs should be
such a situation, they transfer confirmed problem to investigated: organizational, process, human factors, and
maintenance engineers that are capable to solve stated product challenges.
problem (see Figure 1). The activities at back-end are
problem investigation, identification of problem causes
(from technical point of view), problem resolving, testing A. Organizational challenges
and delivery of solutions. At this level are performed Organizational challenges are related to the size and
typical software maintenance and evolution tasks related the complexity of a software company that put restrictions
to modification of software products. on organizing effective support. The questions are:
Feedback between persons on all levels presented at • Do software VSEs have enough resources (human
Figure 1 is important for proper and efficient functioning and technical) to provide effective support to their
of support. In the context of software maintenance support customers?
that is composed from social and technical elements, the
term feedback have the meaning like in management • What expertise is needed and how to acquire it in
psychology and human factors research. Feedback relates order to provide effective support? This aspect is
to the presentation of information to individuals regarding concerned with knowledge, skills, and experience
different aspects of performance, such as behavior, of software maintenance personnel.
strategies, or outcomes [26]. Feedback has many • What other barriers (social, administrative,
dimensions such as source, timing, specificity, type, and political, and cultural) companies meet in
frequency. Feedback provides information on how well organizing and providing support?
and effective individuals are performing relative to their
goals, how effective specific behaviors are for a given • Outsourcing. How company deals with problems
task, and also suggests how much task effort is required to that arise during outsourcing products and
achieve specific objectives [27]. services. This is very important because some
very small companies do outsourcing to larger
companies worldwide.
IV. CHALLENGES FOR VERY SMALL SOFTWARE COMPANIES
Small companies are dominant in economies across B. Process challenges
the globe [28]. U.S. Census Bureau’s “1995 County
Process challenges are related to defining and
Business Patterns” pointed that the vast majority of
establishing effective support processes. The directions for
software and data processing companies are small, and
investigation are:
that those with more than 50 employees comprise only a
few percent of the total number [29]. Laporte et al. • Definition of processes and problems of
reported in [30] that in Europe, 85% of IT sector adherence. This includes investigations which
companies have between 1 and 10 employees, while in processes exist, are they formalized and agreed
Montréal area in Canada over 50% have fewer than 10 with standards or company business policies, and
employees. Organizations that have less than 25 if there is any automated support for processes.
employees are defined as very small enterprises (VSEs)
[30][31][32]. The common situation in the majority of • Communication within a software company. This
software VSEs is that many individuals are responsible for includes communication between people, between
multiple roles (developer, architect, manager and team teams or departments, and communication with
leader) [33]. Because of many unexpected problems, other software companies that deliver third party
improvisation is common in the practice [34]. software components or services.
Comprehensive breakdown of the proposed infrastructure • Customer satisfaction. This includes: how
and support processes for software VSEs is presented in software company meets customer expectations
[32]. This breakdown includes all activities during the (realistic and unrealistic), does customer
whole life cycle of software. orientation increases business of both software
company and customer, does company provide Serbia under the project number TR32044 “The
continuous feedback to customers (demands, development of software tools for business process
requests, products), contracts and service level analysis and improvement”, 2011-2014.
agreements. Active involvement of users in
maintenance is important and can positively affect REFERENCES
customer satisfaction [36].
[1] M. Kans, “The advancement of maintenance information
C. Challenges realted to human factors technology: A literature review”, Journal of Quality in
Software engineering is human activity with different Maintenance Engineering, vol. 5, no. 1, 2009, pp. 5-16, DOI:
roles (engineers, designers, managers, users) and 10.1108/13552510910943859.
behaviors (motivation, communication, understanding) of [2] I. Alsyouf, “The role of maintenance in improving companies'
productivity and pro_tability’, International Journal of Production
involved people. Challenges in software companies are Economics, vol. 105, no. 1, 2007, pp. 70-78, DOI:
related to shortage with maintenance personnel, and their 10.1016/j.ijpe.2004.06.057.
competences and attitude towards support tasks (in many [3] M. Kans and A. Ingwald, “Common database for cost-efective
cases indifferent or detached attitude), while at customer improvement of maintenance performance”, International Journal
side challenges are related to their knowledge about the of Production Economics, vol. 113, no. 2, 2008, pp. 734-747,
used software products, and proper usage of software DOI: 10.1016/j.ijpe.2007.10.008.
products. Investigation of these, human or people factors [4] R. D. Cigolini, A. V. Deshmukh, L. Fedele, and S. A. McComb,
editors. Recent Advances in Maintenance and Infrastructure
requires usage of sociological and psychological aspects Management, Springer London, London, UK, 2009. DOI:
of human behaviors [37][38]. 10.1007/978-1-84882-489-8.
[5] G. Parikh, “Exploring the world of software maintenance: what is
D. Product challenges software maintenance?”, ACM SIGSOFT Software Engineering
Notes, vol. 1, no. 2, April 1986, pp. 49-52, DOI:
Many attributes of software products affect 10.1145/382248.382820.
maintenance support activities. These attributes are [6] I. Sommerville, Software engineering, 6th edition, Addison-
product quality, product complexity, maintainability, user- Wesley Longman Publishing Co., Inc., Boston, MA, USA, 2001.
friendliness, etc. It is challenging to investigate how these [7] S. Mamone, “The IEEE standard for software maintenance”, ACM
attributes correlate, and how they affect processes, and all SIGSOFT Software Engineering Notes, vol. 19, no. 1, 1994, pp.
people involved in maintenance support activities. 75-76, DOI: 10.1145/181610.181623.
[8] J. Singer, “Practices of Software Maintenance”, In Proceedings of
the International Conference on Software Maintenance, ICSM '98,
V. CONCLUSIONS pp. 139_, Washington, DC, USA, 1998.
In this paper are presented challenges that software [9] J. Connell and L. Brice, “Prolonging the life of software”, In
companies face in the field of maintenance support Proceedings of the July 9-12, 1984, national computer conference
and exposition, AFIPS '84, pp. 243-249, New York, USA, 1984,
towards their clients. These challenges are not only ACM, DOI: 10.1145/1499310.1499342.
technical or technological, but are also related to
[10] E. Arisholm, L. C. Briand, S. E. Hove and Y. Labiche, “The
organization and management, social and cultural context. Impact of UML Documentation on Software Maintenance: An
The main characteristics of software VSEs have been Experimental Evaluation”, IEEE Transactions on Software
presented in available literature (see section IV of this Engineering, vol. 32, no. 6, June 2006, pp. 365-381, DOI:
paper), and the question is: How software VSEs meet 10.1109/TSE.2006.59.
presented challenges in the field of maintenance support? [11] P. Stachour and D. Collier-Brown, “You Don't Know Jack About
Software Maintenance”, Communications of the ACM, vol. 52,
Although many international standards (for example no. 11, 2009, pp. 54-58, DOI: 10.1145/1592761.1592777.
ISO 29110 Software process lifecycles for very small [12] R. Mookerjee, “Maintaining enterprise software applications”,
entities) have been recently developed and adapted to Communications of the ACM, vol. 48, no. 11, pp. 75-79,
November 2005, DOI: 10.1145/1096000.1096008.
software VSEs [39], the most of small software companies
do not accept them nor plan to do that [40]. Survey of [13] B. A. Kitchenham, G. H. Travassos, A. von Mayrhauser, F.
Niessink, N. F. Schneidewind, J. Singer, S. Takada, R.
existing literature provides the evidence that there is a Vehvilainen and H. Yang, “Towards an ontology of software
limited amount of empirical research investigating the maintenance’, Journal of Software Maintenance: Research and
support activities in software VSEs. Practice, vol. 11, no. 6, 1999, pp. 365-389.
[14] R. D. Banker and S. A. Slaughter, “A field study of scale
Further research should be directed towards economies in software maintenance”, Management Science, vol.
assessment of current practice, and development and 43, no. 12, Frontier Research on Information Systems and
implementation of appropriate tools and methods that will Economics, 1997, pp. 1709-1725, DOI: 10.1287/mnsc.43.12.1709.
improve the practice. One of the main problems in small [15] S. R. Schach, B. Jin, L. Yu, G. Z. Heller and J. Offutt,
software companies is the lack of time and resources to “Determining the Distribution of Maintenance Categories: Survey
invest in the research. This problem can be overcome versus Measurement”, Empirical Software Engineering, vol. 8, no.
4, 2003, 351-365, DOI: 10.1023/A:1025368318006.
through cooperation with universities, or joint
[16] C. F. Kemerer and S. A. Slaughter, “Determinants of software
development and service providing by more small maintenance profiles: an empirical investigation”, Journal of
companies. Software Maintenance, vol. 9, no. 4, July 1997, pp.235-251. DOI:
10.1002/(SICI)1096-908X(199707/08)9:4<235::AID-
SMR153>3.0.CO;2-3.
ACKNOWLEDGMENT
[17] F. Niessink and H. van Vliet, “Software maintenance from a
This research is financially supported by Ministry of service perspective”, Journal of Software Maintenance: Research
Science and Technological Development, Republic of and Practice, vol. 12, issue 2, March/April 2000, pp. 103–120.
[18] J. Bouman, J. Trienekens and M. Van der Zwan, “Specification of [30] C.Y. Laporte, A. Renault, S. Alexandre and T. Uthayanaka, “The
Service Level Agreements, Clarifying Concepts on the Basis of Application of ISO/IEC JTC 1/SC7 Software Engineering
Practical Research”, In Proceedings of the Software Technology Standards in Very Small Enterprises”, ISO Focus, International
and Engineering Practice (STEP '99), 169-178. DOI: Organisation for Standardisation, September 2006, pp 36-38.
10.1109/STEP.1999.798790. [31] N. Habra, S. Alexandre, J-M. Desharnais, C. Y. Laporte and A.
[19] S. Heras, J. A. Garcia-Pardo, R. Ramos-Garijo, A. Palomares, V. Renault, “Initiating software process improvement in very small
Botti, M. Rebollo, and V. Julian, “Multi-domain case-based enterprises: Experience with a light assessment tool”, Information
module for customer support”, Expert Systems with Applications, and Software Technology, vol. 50, issues 7-8, June 2008, pp. 763-
vol. 36, issue 3, part 2, April 2009, pp. 6866-6873, DOI: 771, DOI: 10.1016/j.infsof.2007.08.004.
10.1016/j.eswa.2008.08.003. [32] V. Ribaud, P. Saliou, R. V. O’Connor and C. Y. Laporte,
[20] M. Kajko-Mattsson, “Problems within front-end support”, Journal “Software Engineering Support Activities for Very Small
of Software Maintenance and Evolution: Research and Practice, Entities”, Systems, Software and Services Process Improvement,
vol. 16, issue 4-5, 2004, pp. 309-329, DOI: 10.1002/smr.298. Communications in Computer and Information Science, 2010, vol.
[21] M. Kajko-Mattsson, “Taxonomy Of Front-End Support 99, pp. 165-176, DOI: 10.1007/978-3-642-15666-3_1.
Activities”, Journal of Integrated Design & Process Science, vol. [33] A. Rainer, “The Value of Empirical Evidence for Practitioners and
8, issue 1, January 2004, 19-29. Researchers”, Empirical Software Engineering Issues. Critical
[22] M. Kajko-Mattsson, “Infrastructures of Virtual IT Enterprises”, In Assessment and Future Directions, Lecture Notes in Computer
Proceedings of the International Conference on Software Science LNCS 4336, pp. 24, 2007, DOI: 10.1007/978-3-540-
Maintenance 2003 (ICSM '03), 199-208, DOI: 71301-2_8.
10.1109/ICSM.2003.1235422. [34] T. Dyba, “Improvisation in Small Software Organizations”. IEEE
[23] B. T. Pentland, “Organizing Moves in Software Support Hot Software, vol. 17, no. 5, pp. 82-87, DOI=10.1109/52.877872.
Lines”, Administrative Science Quarterly, vol. 37, no. 4, [35] H. Hakala, M. Kohtamäki, “Configurations of entrepreneurial-
December 1992, pp. 527-548. customer- and technology orientation: Differences in learning and
[24] M. Kriegsman and R. Barletta, “Building a Case-Based Help Desk performance of software companies”, International Journal of
Application”, IEEE Expert: Intelligent Systems and Their Entrepreneurial Behaviour & Research, vol. 17, issue 1, pp. 64 -
Applications, vol. 8, no. 6, December 1993, pp. 18-26, DOI: 81, DOI: 10.1108/13552551111107516.
10.1109/64.248349. [36] P. Bhatt, G. Shroff and A. K. Misra, “Dynamics of software
[25] B. T. Pentland, “Bleeding Edge Epistemology: Practical Problem maintenance”, ACM SIGSOFT Software Engineering Notes, vol.
Solving in Software Support Hot Lines”, In Stephen R. Barley and 29, issue 5, September 2004, pp. 1-5,
Julian Edgerton Orr, editors, Between craft and science: technical DOI=10.1145/1022494.1022513.
work in U.S. settings. Ithaca, NY, USA, ILR Press, 1997. [37] H. Sharp and H. Robinson, “Some social factors of software
[26] P. W. B. Atkins, R. E. Wood and P. J. Rutgers, “The effects of engineering: the maverick, community and technical practices”,
feedback format on dynamic decision making”, Organizational ACM SIGSOFT Software Engineering Notes, vol. 30, issue 4,
Behavior and Human Decision Processes, vol. 88, issue 2, July July 2005, pp. 1-6. DOI=10.1145/1082983.1083117.
2002, pp. DOI: 10.1016/S0749-5978(02)00002-X. [38] J. Sillito and E. Wynn, “The Social Context of Software
[27] C. F. Lam, D. S. DeRue, E. P. Karam and J. R. Hollenbeck, “The Maintenance”, In Proceedings of the International Conference on
impact of feedback frequency on learning and task performance: Software Maintenance, icsm 2007, pp. 325-334, DOI:
Challenging the 'more is better' assumption”, Organizational 10.1109/ICSM.2007.4362645.
Behavior and Human Decision Processes, In Press, Corrected [39] C. Y. Laporte, S. Alexandre and A. Renault, “Developing
Proof, DOI: 10.1016/j.obhdp.2011.05.002. International Standards for Very Small Enterprises”, Computer,
[28] I. Richardson and C. G. von Wangenheim, “Guest Editors' vol. 41, no. 3, pp. 98-101. DOI: 10.1109/MC.2008.86.
Introduction: Why are Small Software Organizations Different?”, [40] S. Basri and R. V. O’Connor, “Understanding the Perception of
IEEE Software, vol. 24, No. 1, 2007, pp. 18-22, DOI: Very Small Software Companies towards the Adoption of Process
10.1109/MS.2007.12. Standards”, Systems, Software and Services Process
[29] M. E. Fayad, M. Laitinen and R. P. Ward, “Thinking objectively: Improvement, Communications in Computer and Information
software engineering in the small”, Communications of the ACM, Science, 2010, Volume 99, pp. 153-164, DOI: 10.1007/978-3-642-
vol. 43, issue 3, March 2000, pp. 115-118, DOI: 15666-3_14.
10.1145/330534.330555.

View publication stats

You might also like