AirJD 焦点
AirJD

没有录音文件
00:00/00:00
加收藏

Ruby重构初步-SO YOU WANT TO START REFACTORING by JILLIAN FOLEY

发布者 rubyconf
发布于 1440723996257  浏览 5451 关键词 Ruby, English 
分享到

第1页

JILLIAN FOLEY • RAILSCONF 2015

SO YOU WANT



TO



START REFACTORING?



第2页

ABOUT ME

•Software engineer at Contactually •Learned coding on-the-job •Pretty much only worked in legacy code



第4页

SO WHAT IS REFACTORING?



第5页

“Refactoring is a disciplined technique for restructuring an existing body of code, altering its

internal structure without changing its external behavior."

–MARTIN FOWLER



第6页

THE IDEA IS

• No change to your users • Improvement for

developers



第8页

BUT … WHY?



第9页

“Refactoring? No way. We need new features!”

–YOUR MANAGER



第10页

• Maintainability • Scalability • Flexibility • Spring cleaning



第11页

HOW WILL I KNOW WHEN IT’S TIME TO REFACTOR?



第12页

OVERWHELMED BY BUGS

DECREASED PERFORMANCE N00B SAYS WTF

TAKE A LOOK

WINTER IS COMING



第13页

TESTS ARE HARD TO WRITE

BLOCKING NEW PROGRESS

PRODUCTION CRASHES

DO IT YESTERDAY!



第14页

SO HOW DO YOU DO IT?



第15页

P R E PA R E

MISE EN PLACE, FOR CODE

• Beef up your test coverage

• Review functionality x 100 • Brush up on code style

guides and preferences



第16页

ANNOTATE

MARK UP SMELLY CODE

• Read through and comment anything that looks weird, bad, wrong, or confusing

• Consider copying dependencies temporarily

• Rename variables and methods



第17页

INVESTIGATE

LOOK FOR CODE MESSES

• What looks redundant? • What looks too complex? • What parts of the code took more

than 1-2 reads to understand? • Do you see any methods that

look bloated? • Does any of it violate code style

standards?



第18页

CLEAN UP

GIVE YOUR CODE A MAKEOVER

• Focus on one method at a time • DRY it up • Pick better names • Fix style issues • Simplify conditionals • Break down complex methods • Move code where it truly belongs



第19页

A VERY BRIEF CASE STUDY



第20页

!

email = params[:signup].delete(:email).to_s.gsub(/\s/, '').downcase[0..100]

! !

unless u = User.find_by_email(email) if a = Account.email.find_by_username(email)

!

u=a end end

! !

if u if email != "demo@contactually.com" flash[:notice] = "Looks like you already have an account." redirect_to new_user_session_path(:exists => true) return true

!

else sign_in(u) redirect_to signup_accounts_path return true

end end



第21页

# Does this assignment need to be so long? Why is the param key :signup ? email = params[:signup].delete(:email).to_s.gsub(/\s/, '').downcase[0..100]

!

# This nested unless/if makes my brain hurt. unless u = User.find_by_email(email)

if a = Account.email.find_by_username(email) # Is there some way to consolidate these two u assignments? u = a # wtf are these single-letter variables

end end

!

# Ew another nested if if u

if email != "demo@contactually.com" flash[:notice] = "Looks like you already have an account." redirect_to new_user_session_path(:exists => true) return true

# Using the negative in the first if makes this 'else' confusing else

sign_in(u) redirect_to signup_accounts_path return true end end



第22页

email = params[:user][:email]

!

# Try to find an existing user by email or account existing_user = User.find_by_email(email) ||

Account.email.find_by_username(email).try(&:user)

!

# Push demo user through to demo signup if existing_user && email == 'demo@contactually.com'

sign_in(existing_user) redirect_to signup_accounts_path return true end

!

if existing_user flash[:notice] = "Looks like you already have an account with

Contactually." redirect_to new_user_session_path(:exists => true) return true

end



第23页

OTHER TIPS

• Test frequently, both manually and automated. • Don’t change tests while refactoring! • Commit frequently. • Use tools like Rubocop or Reek for help when you’re

overwhelmed or stuck • Consider pausing after a logical group of changes to

do more testing, code review, and deploy . . .



第24页

“INCREMENTAL”

SLOW AND STEADY WINS THE RACE?



“BIG BANG”

OMG I WANT ALL THE CHANGES!!!11



第25页

THINGS TO REMEMBER

• Refactoring isn’t scary • It’s a good way to learn new design patterns • It’s a good way to learn your codebase • Tests can be refactored too! • Go back and refactor old projects for practice



第26页

GO FORTH AND REFACTOR!



第27页

QUESTIONS?

J I L L I A N @ C O N TA C T U A L LY. C O M @J3FOLEY



第28页

APPENDIX: FURTHER READING

!

• Martin Fowler's site to accompany his Refactoring book • The Ruby version of above Refactoring book, by Jay

Fields, Shane Harvie, and Martin Fowler • Ginny Hendry's notes from the Ruby version of the

Refactoring book • Codecademy Ruby refactoring exercise



支持文件格式:*.pdf
上传最后阶段需要进行在线转换,可能需要1~2分钟,请耐心等待。