SlideShare a Scribd company logo
1 of 30
Download to read offline
What Programmers Say About
Refactoring Tools?
An Empirical Investigation of StackOverflow

Gustavo Pinto, Fernando Kamei
Federal University of Pernambuco
{ghlp, fkk}@cin.ufpe.br
Researchers

Programmers
Programmers

Researchers

What they think about?
Programmers

Researchers

What they think about?
Programmers

Researchers

What they think about?
1.5M Users
3.4M Questions
6.8M Answers
40GB of data
A TON of information
(with some quality)
1.5M Users
3.4M Questions
6.8M Answers
40GB of data
A TON of information
(with some quality)

But, what about
Refactoring Tools?
3.4M Questions

Filter questions by “refactoring”
and “tools” on the body, or
subject or tag name.

Store the results in a
single MySQL table.

754 Q
>2K A

from July 31, 2008
to July 31, 2012:
●
●
●

324 Questions
1,135 Answers
1,254 Users
The final data!

Manual filter to remove
false positives
3.4M Questions

Filter questions by “refactoring”
and “tools” key-word, on the
body, or subject or tag name.

Store the results in a
single MySQL table.

754 Q
>2K A

from July 31, 2008
to July 31, 2012:
●
●
●

324 Questions
1,135 Answers
1,254 Users
The final data!

Manual filter to remove
false positives
3.4M Questions

Filter questions by “refactoring”
and “tools” key-word, on the
body, or subject or tag name.

Store the results in a
single MySQL table.

754 Q
>2K A

from July 31, 2008
to July 31, 2012:
●
●
●

324 Questions
1,135 Answers
1,254 Users

2x
The final data!

Manual filter to remove
false positives
Research Questions
● RQ1: What are the most desirable features in
refactoring tools?
● RQ2: What are the barriers to adoption of refactoring
tools?
● RQ3: How is interest in refactoring tools related to
programmer expertise?
● RQ4: Does interest in refactoring tools increase over
the years?
RQ1: What are the most desirable features in refactoring tools?
1. Refactoring for dynamic languages (78 questions ≈ 24.72%)
a. PHP
» 29%
“I am looking for a python tool that will allow
b. JavaScript
» 23%
me to specifically rename and move
c. Python
» 23%
modules.”
d. Ruby
» 11%
StackOverflow Question #9424189
e. Perl
» 9%
f. R
» 1%
g. Perl
» 1%
h. Matlab
» 1%
RQ1: What are the most desirable features in refactoring tools?
1. Refactoring for dynamic languages (78 questions ≈ 24.72%)
2. Refactoring recommendations (45 questions ≈ 13.88%)
“I would prefer a tool that just makes suggestions about possible refactorings: names
the refactoring, optionally provides a short description of it (great for learning purposes),
highlights the code section and lets me do the refactoring myself”
StackOverflow Question #785667
RQ1: What are the most desirable features in refactoring tools?
1. Refactoring for dynamic languages (78 questions ≈ 24.72%)
2. Refactoring recommendations (45 questions ≈ 13.88%)
3. Refactoring for databases (12 questions ≈ 3.71%)
a. Automatic simplification of SQL
b. Refactoring table or views structure
c. Fixing SQL vulnerabilities
“I would like to rename a table column in MySql and also have the name updated in any triggers,
stored procs, etc. that reference the column. [...] If a tool exists that can perform such a
refactoring, it would be great if it could generate an SQL script that applies these changes.”
StackOverflow Question #1644271
RQ1: What are the most desirable features in refactoring tools?
1.
2.
3.
4.

Refactoring for dynamic languages (78 questions ≈ 24.72%)
Refactoring recommendations (45 questions ≈ 13.88%)
Refactoring for databases (12 questions ≈ 3.71%)
Multi-language Refactorings (9 questions ≈ 2.77%)
a. All questions related to JVM languages

“I have inherited significant amounts of Groovy code, and I have found it difficult to maintain [..]. I
have tried to manually convert some pieces to Java, it's been a pain. Are you aware of any tools
or plugins that help with this conversion?”
StackOverflow Question #5302103
RQ2: What are the barriers to adoption of refactoring tools?
In order of interest:

1. Usability problems (52 questions ≈ 16%)
1.1. Unknown tool (54%)
1.2. Difficult to learn (13%)
1.3. Difficult to use (8%)
2. Lack of trust (39 questions ≈ 12%)
RQ2: What are the barriers to adoption of refactoring tools?
In order of interest:

1. Usability problems (16% of Q)
1.1. Unknown tool (54%)
1.2. Difficult to learn (13%)
1.3. Difficult to use (8%)

33% are from novice users
64%
49%

What refactoring tool
do you use to do X in
language Z?
RQ2: What are the barriers to adoption of refactoring tools?
In order of interest:

1. Usability problems (16% of Q)
1.1. Unknown tool (54%)
1.2. Difficult to learn (13%)
1.3. Difficult to use (8%)

Barriers or lack of experience?

33% are from novice users
64%
49%

What refactoring tool
do you use to do X in
language Z?
RQ2: What are the barriers to adoption of refactoring tools?
In order of interest:

1. Usability problems (16% of Q)
1.1. Unknown tool (54%)
1.2. Difficult to learn (13%)
1.3. Difficult to use (8%)
2. Lack of trust (12 % of Q)

Sometimes the tool will change
the meaning of your code,
without you expecting it.

StackOverflow Question #1372059
RQ2: What are the barriers to adoption of refactoring tools?
In order of interest:

1. Usability problems (16% of Q)
1.1. Unknown tool (54%)
1.2. Difficult to learn (13%)
1.3. Difficult to use (8%)
2. Lack of trust (12 % of Q)

“It is not good to decrease readability in
favor of atomicity”
StackOverflow Question #5302103

Sometimes the tool will change
the meaning of your code,
without you expecting it.

StackOverflow Question #1372059
RQ3: How is interest in refactoring tools related to programmer
expertise?
Or.. do only hackers talk about refactoring tools?
RQ3: How is interest in refactoring tools related to programmer
expertise?
Or.. do only hackers talk about refactoring tools?

Q: 39% comes from novices
A: 41% comes from seniors

Novices

Seniors
RQ3: How is interest in refactoring tools related to programmer
expertise?
Or.. do only hackers talk about refactoring tools?

Q: 39% comes from novices
A: 41% comes from seniors

Refactoring tool is a topic that
interest all kind of users.

Novices

Seniors
RQ3: How is interest in refactoring tools related to programmer
expertise?
Or.. do only hackers talk about refactoring tools?

Q: 39% comes from novices
A: 41% comes from seniors

Novices

Seniors

Also, we ran a Person
Correlation between reputation x
questions and reputation x
answers, but no significant
correlation was found.
RQ4: Does interest in refactoring tools increase over the years?
Questions per month
● Median: 6
● Mean: 6.75
● SD: 3.38
● Max: 20
● Min: 1
Answers per month
● Median: 18
● Mean: 23.63
● SD: 16.23
● Max: 73
● Min: 1
RQ4: Does interest in refactoring tools increase over the years?
Questions per month
● Median: 6
● Mean: 6.75
● SD: 3.38
● Max: 20
● Min: 1

● Yes, but very little.

Answers per month
● Median: 18
● Mean: 23.63
● SD: 16.23
● Max: 73
● Min: 1
RQ4: Does interest in refactoring tools increase over the years?
Questions per month
● Median: 6
● Mean: 6.75
● SD: 3.38
● Max: 20
● Min: 1

● Yes, but very little.
● An increment of 0.56 questions per trimester.
● A decrement of -8.13 answers per trimester.

Answers per month
● Median: 18
● Mean: 23.63
● SD: 16.23
● Max: 73
● Min: 1
RQ4: Does interest in refactoring tools increase over the years?
Questions per month
● Median: 6
● Mean: 6.75
● SD: 3.38
● Max: 20
● Min: 1

-0.43 without outliers

● Yes, but very little.
● An increment of 0.56 questions per trimester.
● A decrement of -8.13 answers per trimester.

Answers per month
● Median: 18
● Mean: 23.63
● SD: 16.23
● Max: 73
● Min: 1
Conclusions
● We provided a set of desired features, as well as common
cause for barriers adoption.
○ Insights for researchers and tool vendors
● We observed that novice users produce more questions, and
seniors provide the answers.
○ Also, most of the barriers were reported by novice users
● We identified a relative small interest in refactoring tools
○ Mean of 6 questions / month, sd of 4.45
What Programmers Say About
Refactoring Tools?
An Empirical Investigation of StackOverflow

Gustavo Pinto, Fernando Kamei
Federal University of Pernambuco
{ghlp, fkk}@cin.ufpe.br

More Related Content

Similar to What Programmers Say About Refactoring Tools? An Empirical Investigation of StackOverflow 

Are Automated Debugging Techniques Actually Helping Programmers
Are Automated Debugging Techniques Actually Helping ProgrammersAre Automated Debugging Techniques Actually Helping Programmers
Are Automated Debugging Techniques Actually Helping ProgrammersChris Parnin
 
Overcome the Reign of Chaos
Overcome the Reign of ChaosOvercome the Reign of Chaos
Overcome the Reign of ChaosMichael Stockerl
 
Evaluating the Usefulness of IR-Based Fault LocalizationTechniques
Evaluating the Usefulness of IR-Based Fault LocalizationTechniquesEvaluating the Usefulness of IR-Based Fault LocalizationTechniques
Evaluating the Usefulness of IR-Based Fault LocalizationTechniquesAlex Orso
 
Code-Review-COW56-Meeting
Code-Review-COW56-MeetingCode-Review-COW56-Meeting
Code-Review-COW56-MeetingMasud Rahman
 
Pragmatic software testing education - SIGCSE 2019
Pragmatic software testing education - SIGCSE 2019Pragmatic software testing education - SIGCSE 2019
Pragmatic software testing education - SIGCSE 2019Maurício Aniche
 
[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language Models
[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language Models[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language Models
[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language ModelsDataScienceConferenc1
 
Works For Me! Characterizing Non-Reproducible Bug Reports
Works For Me! Characterizing Non-Reproducible Bug ReportsWorks For Me! Characterizing Non-Reproducible Bug Reports
Works For Me! Characterizing Non-Reproducible Bug ReportsSALT Lab @ UBC
 
Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...
Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...
Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...University of Saskatchewan
 
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptxDesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptxJoseph Beale
 
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptxDesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptxQA or the Highway
 
DesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptxDesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptxQA or the Highway
 
Teacher-Aware Active Robot Learning
Teacher-Aware Active Robot LearningTeacher-Aware Active Robot Learning
Teacher-Aware Active Robot LearningMattia Racca
 
StratCel: A Strategy-Centric Approach to the Design of End-User Debugging Tools
StratCel: A Strategy-Centric Approach to the Design of End-User Debugging ToolsStratCel: A Strategy-Centric Approach to the Design of End-User Debugging Tools
StratCel: A Strategy-Centric Approach to the Design of End-User Debugging Toolshciresearch
 
From Chatbots to Augmented Conversational Assistants
From Chatbots to Augmented Conversational AssistantsFrom Chatbots to Augmented Conversational Assistants
From Chatbots to Augmented Conversational AssistantsDatabricks
 
MS.Net Interview Questions - Simplified
MS.Net Interview Questions - SimplifiedMS.Net Interview Questions - Simplified
MS.Net Interview Questions - SimplifiedMohd Manzoor Ahmed
 
An introduction to R is a document useful
An introduction to R is a document usefulAn introduction to R is a document useful
An introduction to R is a document usefulssuser3c3f88
 
Bug debug keynote - Present problems and future solutions
Bug debug keynote - Present problems and future solutionsBug debug keynote - Present problems and future solutions
Bug debug keynote - Present problems and future solutionsRIA RUI Society
 

Similar to What Programmers Say About Refactoring Tools? An Empirical Investigation of StackOverflow  (20)

Are Automated Debugging Techniques Actually Helping Programmers
Are Automated Debugging Techniques Actually Helping ProgrammersAre Automated Debugging Techniques Actually Helping Programmers
Are Automated Debugging Techniques Actually Helping Programmers
 
Overcome the Reign of Chaos
Overcome the Reign of ChaosOvercome the Reign of Chaos
Overcome the Reign of Chaos
 
Evaluating the Usefulness of IR-Based Fault LocalizationTechniques
Evaluating the Usefulness of IR-Based Fault LocalizationTechniquesEvaluating the Usefulness of IR-Based Fault LocalizationTechniques
Evaluating the Usefulness of IR-Based Fault LocalizationTechniques
 
Code-Review-COW56-Meeting
Code-Review-COW56-MeetingCode-Review-COW56-Meeting
Code-Review-COW56-Meeting
 
To Mock or Not To Mock
To Mock or Not To MockTo Mock or Not To Mock
To Mock or Not To Mock
 
Pragmatic software testing education - SIGCSE 2019
Pragmatic software testing education - SIGCSE 2019Pragmatic software testing education - SIGCSE 2019
Pragmatic software testing education - SIGCSE 2019
 
[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language Models
[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language Models[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language Models
[DSC Europe 23] Dmitry Ustalov - Design and Evaluation of Large Language Models
 
Sporar
SporarSporar
Sporar
 
Works For Me! Characterizing Non-Reproducible Bug Reports
Works For Me! Characterizing Non-Reproducible Bug ReportsWorks For Me! Characterizing Non-Reproducible Bug Reports
Works For Me! Characterizing Non-Reproducible Bug Reports
 
Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...
Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...
Investigating the Quality Aspects of Crowd-Sourced Developer Forum: A Case St...
 
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptxDesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
 
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptxDesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers & Testing in ChatGPT-AI world.pptx
 
DesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptxDesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptx
DesiradhaRam Gadde - Testers _ Testing in ChatGPT-AI world.pptx
 
Teacher-Aware Active Robot Learning
Teacher-Aware Active Robot LearningTeacher-Aware Active Robot Learning
Teacher-Aware Active Robot Learning
 
Kodisto Dojo 16-01 notes (2015-01-14)
Kodisto Dojo 16-01 notes (2015-01-14)Kodisto Dojo 16-01 notes (2015-01-14)
Kodisto Dojo 16-01 notes (2015-01-14)
 
StratCel: A Strategy-Centric Approach to the Design of End-User Debugging Tools
StratCel: A Strategy-Centric Approach to the Design of End-User Debugging ToolsStratCel: A Strategy-Centric Approach to the Design of End-User Debugging Tools
StratCel: A Strategy-Centric Approach to the Design of End-User Debugging Tools
 
From Chatbots to Augmented Conversational Assistants
From Chatbots to Augmented Conversational AssistantsFrom Chatbots to Augmented Conversational Assistants
From Chatbots to Augmented Conversational Assistants
 
MS.Net Interview Questions - Simplified
MS.Net Interview Questions - SimplifiedMS.Net Interview Questions - Simplified
MS.Net Interview Questions - Simplified
 
An introduction to R is a document useful
An introduction to R is a document usefulAn introduction to R is a document useful
An introduction to R is a document useful
 
Bug debug keynote - Present problems and future solutions
Bug debug keynote - Present problems and future solutionsBug debug keynote - Present problems and future solutions
Bug debug keynote - Present problems and future solutions
 

More from UFPA

Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...
Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...
Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...UFPA
 
More Common Than You Think: An In-Depth Study of Casual Contributors
More Common Than You Think: An In-Depth Study of Casual ContributorsMore Common Than You Think: An In-Depth Study of Casual Contributors
More Common Than You Think: An In-Depth Study of Casual ContributorsUFPA
 
Possibilidades com python
Possibilidades com pythonPossibilidades com python
Possibilidades com pythonUFPA
 
Python simplecv
Python simplecvPython simplecv
Python simplecvUFPA
 
Porque aprender haskell me fez um programador python melhor?
Porque aprender haskell me fez um programador python melhor?Porque aprender haskell me fez um programador python melhor?
Porque aprender haskell me fez um programador python melhor?UFPA
 
Are Java Programmers Transitioning to Multicore?
Are Java Programmers Transitioning to Multicore? Are Java Programmers Transitioning to Multicore?
Are Java Programmers Transitioning to Multicore? UFPA
 
Beljug2010
Beljug2010Beljug2010
Beljug2010UFPA
 
Grails from scratch
Grails from scratchGrails from scratch
Grails from scratchUFPA
 
A computacao e_voce_caminhos_para_seguir
A computacao e_voce_caminhos_para_seguirA computacao e_voce_caminhos_para_seguir
A computacao e_voce_caminhos_para_seguirUFPA
 

More from UFPA (9)

Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...
Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...
Evidence Briefings: Towards a Medium to Transfer Knowledge from Systematic Re...
 
More Common Than You Think: An In-Depth Study of Casual Contributors
More Common Than You Think: An In-Depth Study of Casual ContributorsMore Common Than You Think: An In-Depth Study of Casual Contributors
More Common Than You Think: An In-Depth Study of Casual Contributors
 
Possibilidades com python
Possibilidades com pythonPossibilidades com python
Possibilidades com python
 
Python simplecv
Python simplecvPython simplecv
Python simplecv
 
Porque aprender haskell me fez um programador python melhor?
Porque aprender haskell me fez um programador python melhor?Porque aprender haskell me fez um programador python melhor?
Porque aprender haskell me fez um programador python melhor?
 
Are Java Programmers Transitioning to Multicore?
Are Java Programmers Transitioning to Multicore? Are Java Programmers Transitioning to Multicore?
Are Java Programmers Transitioning to Multicore?
 
Beljug2010
Beljug2010Beljug2010
Beljug2010
 
Grails from scratch
Grails from scratchGrails from scratch
Grails from scratch
 
A computacao e_voce_caminhos_para_seguir
A computacao e_voce_caminhos_para_seguirA computacao e_voce_caminhos_para_seguir
A computacao e_voce_caminhos_para_seguir
 

Recently uploaded

Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationRadu Cotescu
 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘RTylerCroy
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProduct Anonymous
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slidevu2urc
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024Rafal Los
 
Tech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdfTech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdfhans926745
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024The Digital Insurer
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfsudhanshuwaghmare1
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024The Digital Insurer
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024The Digital Insurer
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerThousandEyes
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Miguel Araújo
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?Igalia
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsMaria Levchenko
 
Developing An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilDeveloping An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilV3cube
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Drew Madelung
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...apidays
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAndrey Devyatkin
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdfhans926745
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc
 

Recently uploaded (20)

Scaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organizationScaling API-first – The story of a global engineering organization
Scaling API-first – The story of a global engineering organization
 
🐬 The future of MySQL is Postgres 🐘
🐬  The future of MySQL is Postgres   🐘🐬  The future of MySQL is Postgres   🐘
🐬 The future of MySQL is Postgres 🐘
 
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemkeProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
ProductAnonymous-April2024-WinProductDiscovery-MelissaKlemke
 
Histor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slideHistor y of HAM Radio presentation slide
Histor y of HAM Radio presentation slide
 
The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024The 7 Things I Know About Cyber Security After 25 Years | April 2024
The 7 Things I Know About Cyber Security After 25 Years | April 2024
 
Tech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdfTech Trends Report 2024 Future Today Institute.pdf
Tech Trends Report 2024 Future Today Institute.pdf
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
Boost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdfBoost Fertility New Invention Ups Success Rates.pdf
Boost Fertility New Invention Ups Success Rates.pdf
 
Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024Tata AIG General Insurance Company - Insurer Innovation Award 2024
Tata AIG General Insurance Company - Insurer Innovation Award 2024
 
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
Bajaj Allianz Life Insurance Company - Insurer Innovation Award 2024
 
How to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected WorkerHow to Troubleshoot Apps for the Modern Connected Worker
How to Troubleshoot Apps for the Modern Connected Worker
 
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
Mastering MySQL Database Architecture: Deep Dive into MySQL Shell and MySQL R...
 
A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?A Year of the Servo Reboot: Where Are We Now?
A Year of the Servo Reboot: Where Are We Now?
 
Handwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed textsHandwritten Text Recognition for manuscripts and early printed texts
Handwritten Text Recognition for manuscripts and early printed texts
 
Developing An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of BrazilDeveloping An App To Navigate The Roads of Brazil
Developing An App To Navigate The Roads of Brazil
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
Apidays Singapore 2024 - Building Digital Trust in a Digital Economy by Veron...
 
AWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of TerraformAWS Community Day CPH - Three problems of Terraform
AWS Community Day CPH - Three problems of Terraform
 
[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf[2024]Digital Global Overview Report 2024 Meltwater.pdf
[2024]Digital Global Overview Report 2024 Meltwater.pdf
 
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law DevelopmentsTrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
TrustArc Webinar - Stay Ahead of US State Data Privacy Law Developments
 

What Programmers Say About Refactoring Tools? An Empirical Investigation of StackOverflow 

  • 1. What Programmers Say About Refactoring Tools? An Empirical Investigation of StackOverflow Gustavo Pinto, Fernando Kamei Federal University of Pernambuco {ghlp, fkk}@cin.ufpe.br
  • 6. 1.5M Users 3.4M Questions 6.8M Answers 40GB of data A TON of information (with some quality)
  • 7. 1.5M Users 3.4M Questions 6.8M Answers 40GB of data A TON of information (with some quality) But, what about Refactoring Tools?
  • 8. 3.4M Questions Filter questions by “refactoring” and “tools” on the body, or subject or tag name. Store the results in a single MySQL table. 754 Q >2K A from July 31, 2008 to July 31, 2012: ● ● ● 324 Questions 1,135 Answers 1,254 Users The final data! Manual filter to remove false positives
  • 9. 3.4M Questions Filter questions by “refactoring” and “tools” key-word, on the body, or subject or tag name. Store the results in a single MySQL table. 754 Q >2K A from July 31, 2008 to July 31, 2012: ● ● ● 324 Questions 1,135 Answers 1,254 Users The final data! Manual filter to remove false positives
  • 10. 3.4M Questions Filter questions by “refactoring” and “tools” key-word, on the body, or subject or tag name. Store the results in a single MySQL table. 754 Q >2K A from July 31, 2008 to July 31, 2012: ● ● ● 324 Questions 1,135 Answers 1,254 Users 2x The final data! Manual filter to remove false positives
  • 11. Research Questions ● RQ1: What are the most desirable features in refactoring tools? ● RQ2: What are the barriers to adoption of refactoring tools? ● RQ3: How is interest in refactoring tools related to programmer expertise? ● RQ4: Does interest in refactoring tools increase over the years?
  • 12. RQ1: What are the most desirable features in refactoring tools? 1. Refactoring for dynamic languages (78 questions ≈ 24.72%) a. PHP » 29% “I am looking for a python tool that will allow b. JavaScript » 23% me to specifically rename and move c. Python » 23% modules.” d. Ruby » 11% StackOverflow Question #9424189 e. Perl » 9% f. R » 1% g. Perl » 1% h. Matlab » 1%
  • 13. RQ1: What are the most desirable features in refactoring tools? 1. Refactoring for dynamic languages (78 questions ≈ 24.72%) 2. Refactoring recommendations (45 questions ≈ 13.88%) “I would prefer a tool that just makes suggestions about possible refactorings: names the refactoring, optionally provides a short description of it (great for learning purposes), highlights the code section and lets me do the refactoring myself” StackOverflow Question #785667
  • 14. RQ1: What are the most desirable features in refactoring tools? 1. Refactoring for dynamic languages (78 questions ≈ 24.72%) 2. Refactoring recommendations (45 questions ≈ 13.88%) 3. Refactoring for databases (12 questions ≈ 3.71%) a. Automatic simplification of SQL b. Refactoring table or views structure c. Fixing SQL vulnerabilities “I would like to rename a table column in MySql and also have the name updated in any triggers, stored procs, etc. that reference the column. [...] If a tool exists that can perform such a refactoring, it would be great if it could generate an SQL script that applies these changes.” StackOverflow Question #1644271
  • 15. RQ1: What are the most desirable features in refactoring tools? 1. 2. 3. 4. Refactoring for dynamic languages (78 questions ≈ 24.72%) Refactoring recommendations (45 questions ≈ 13.88%) Refactoring for databases (12 questions ≈ 3.71%) Multi-language Refactorings (9 questions ≈ 2.77%) a. All questions related to JVM languages “I have inherited significant amounts of Groovy code, and I have found it difficult to maintain [..]. I have tried to manually convert some pieces to Java, it's been a pain. Are you aware of any tools or plugins that help with this conversion?” StackOverflow Question #5302103
  • 16. RQ2: What are the barriers to adoption of refactoring tools? In order of interest: 1. Usability problems (52 questions ≈ 16%) 1.1. Unknown tool (54%) 1.2. Difficult to learn (13%) 1.3. Difficult to use (8%) 2. Lack of trust (39 questions ≈ 12%)
  • 17. RQ2: What are the barriers to adoption of refactoring tools? In order of interest: 1. Usability problems (16% of Q) 1.1. Unknown tool (54%) 1.2. Difficult to learn (13%) 1.3. Difficult to use (8%) 33% are from novice users 64% 49% What refactoring tool do you use to do X in language Z?
  • 18. RQ2: What are the barriers to adoption of refactoring tools? In order of interest: 1. Usability problems (16% of Q) 1.1. Unknown tool (54%) 1.2. Difficult to learn (13%) 1.3. Difficult to use (8%) Barriers or lack of experience? 33% are from novice users 64% 49% What refactoring tool do you use to do X in language Z?
  • 19. RQ2: What are the barriers to adoption of refactoring tools? In order of interest: 1. Usability problems (16% of Q) 1.1. Unknown tool (54%) 1.2. Difficult to learn (13%) 1.3. Difficult to use (8%) 2. Lack of trust (12 % of Q) Sometimes the tool will change the meaning of your code, without you expecting it. StackOverflow Question #1372059
  • 20. RQ2: What are the barriers to adoption of refactoring tools? In order of interest: 1. Usability problems (16% of Q) 1.1. Unknown tool (54%) 1.2. Difficult to learn (13%) 1.3. Difficult to use (8%) 2. Lack of trust (12 % of Q) “It is not good to decrease readability in favor of atomicity” StackOverflow Question #5302103 Sometimes the tool will change the meaning of your code, without you expecting it. StackOverflow Question #1372059
  • 21. RQ3: How is interest in refactoring tools related to programmer expertise? Or.. do only hackers talk about refactoring tools?
  • 22. RQ3: How is interest in refactoring tools related to programmer expertise? Or.. do only hackers talk about refactoring tools? Q: 39% comes from novices A: 41% comes from seniors Novices Seniors
  • 23. RQ3: How is interest in refactoring tools related to programmer expertise? Or.. do only hackers talk about refactoring tools? Q: 39% comes from novices A: 41% comes from seniors Refactoring tool is a topic that interest all kind of users. Novices Seniors
  • 24. RQ3: How is interest in refactoring tools related to programmer expertise? Or.. do only hackers talk about refactoring tools? Q: 39% comes from novices A: 41% comes from seniors Novices Seniors Also, we ran a Person Correlation between reputation x questions and reputation x answers, but no significant correlation was found.
  • 25. RQ4: Does interest in refactoring tools increase over the years? Questions per month ● Median: 6 ● Mean: 6.75 ● SD: 3.38 ● Max: 20 ● Min: 1 Answers per month ● Median: 18 ● Mean: 23.63 ● SD: 16.23 ● Max: 73 ● Min: 1
  • 26. RQ4: Does interest in refactoring tools increase over the years? Questions per month ● Median: 6 ● Mean: 6.75 ● SD: 3.38 ● Max: 20 ● Min: 1 ● Yes, but very little. Answers per month ● Median: 18 ● Mean: 23.63 ● SD: 16.23 ● Max: 73 ● Min: 1
  • 27. RQ4: Does interest in refactoring tools increase over the years? Questions per month ● Median: 6 ● Mean: 6.75 ● SD: 3.38 ● Max: 20 ● Min: 1 ● Yes, but very little. ● An increment of 0.56 questions per trimester. ● A decrement of -8.13 answers per trimester. Answers per month ● Median: 18 ● Mean: 23.63 ● SD: 16.23 ● Max: 73 ● Min: 1
  • 28. RQ4: Does interest in refactoring tools increase over the years? Questions per month ● Median: 6 ● Mean: 6.75 ● SD: 3.38 ● Max: 20 ● Min: 1 -0.43 without outliers ● Yes, but very little. ● An increment of 0.56 questions per trimester. ● A decrement of -8.13 answers per trimester. Answers per month ● Median: 18 ● Mean: 23.63 ● SD: 16.23 ● Max: 73 ● Min: 1
  • 29. Conclusions ● We provided a set of desired features, as well as common cause for barriers adoption. ○ Insights for researchers and tool vendors ● We observed that novice users produce more questions, and seniors provide the answers. ○ Also, most of the barriers were reported by novice users ● We identified a relative small interest in refactoring tools ○ Mean of 6 questions / month, sd of 4.45
  • 30. What Programmers Say About Refactoring Tools? An Empirical Investigation of StackOverflow Gustavo Pinto, Fernando Kamei Federal University of Pernambuco {ghlp, fkk}@cin.ufpe.br