Kai Koenig talks about "Improve your CFML Code Quality (with some Cool Tools)" in this episode of ColdFusion Alive Podcast, with host Michaela Light.
Show notes
Why does code quality matter?
Long code lifetime
Reduce maintenance cost
Easier to read
Reduce bugs without testing
What does code quality mean in practice?
Bad Code smell (see below for article)
Complexity
Bad variable or function naming
Poor var
What tools are there for managing and measuring code quality?
Code review tools
Code of conduct for code reviews
Egoless programming
Rhodecode repository
Upsource from Jetbrains
Static analysis
Lint
Runtime analysis
Code coverage / execution paths
Duplicate code
Code Correctness
Does the code fulfil its spec
Behavior Driven Development
Complexity
McCabe index
# Lines of code per class/component/function
Cyclic dependency trackers
Dependency graph generation
Why is there a lack of tools for CFML in this field?
CF less formal than some other languages
RAD focus
Historically CF attracts a lot of cross-training developers, less of a formal Computer Science background
Allaire, Macromedia and Adobe have not been interested in this aspect of a language ecosystem
What cool tools exist for other languages?
List of tools for static code analysis
Linters
What tools do exist for CF?
Varscoper
A bit stale - no good support for cfscript
CFQueryParam checker
CFLint
Based on CFparser (using ANTLR compiler generator)
Outputs HTML, XML or JSON for Findbugs
2.0 will have API
CFLint code of conduct
Various doc tools
ColdDoc
Stale
DocBox
Home-brew stuff for specific use cases
Why are you proud to use CF?
Can be released rapidly and is maintainable and works well with Java
WWIT for you to make CF more alive this year?
Better CF developer tools
Market position of paid server product - open source version
More publicity for Lucee as open source language
Shift perception
Ortus tools
Ortus buy ColdFusion
What are you looking forward to at CFCAMP?
Let's talk about code quality.
We all agree that our code needs to be functional so that it meets business requirements. We also should aim for code that is well written and maintainable for future changes. There are a lot of elements playing into that. A well thought system architecture is an important foundation. The selection of an appropriate framework could be the next step. In the end you might look at how to format and write your code on a line-by-line basis.
This talk will provide an introduction into code quality. We will look at various aspects around this term first. From there we can investigate different ways how you can perform code analysis. This will help you measure and understand code quality. There is a range of categories of tools available, some of which also support CFML.
In the second part of the talk we'll look at the details and usage of CFLint. CFLint is a static code analyser for CFML that is based on the CFParser project.
Mentioned in this episode
CFCAMP
Bad code smell
CFML Complexity Metric Tool
DocBox
Code coverage
Lucee
Fusion Reactor
DocBox wiki
ColdDoc
CFlint
Intellij CF lint plugin
Adobe CF Builder
Agile eXtreme programming - peer programming
Rhodecode
Upsource from Jetbrains
Smartbear Collaborator
McCabe index - Cyclomatic complexity
Cyclic dependency
Decoupling
Varscoper
CFQueryParam checker
CFLint
CFParser
Antlr parser generator
TeamCity CI
CFLint code of conduct
CFMobile
DroidCon UK conference
Listen to the Audio
Bio
Kai Koenig
Kai Koenig works as a Software Solutions Architect for Ventego Creative in Wellington, New Zealand. He co-founded the company with two partners and also the CTO of Zen Ex Machina, a startup in the fields of digital & user experience consultancy based out of Canberra in Australia.
Kai’s work really comprises a mix of consulting, training, mentoring and actual development work using a range of technologies, common themes being Java, CFML, JavaScript, Android etc. He is well versed in Java and some other JVM-based languages like Clojure or Groovy and recently (re-)discovered the pleasure of writing software in Python and Go. Kotlin is his new language love though.
Back in the day, Kai was doing a lot of front end development work around Adobe Flex, too - that has now pretty much all changed and it's very much Javascript only. He finds a lot of pleasure in using JS with frameworks such as jQueryMobile, KendoUI, Require.js or Angular and in building apps using those technologies.
Other stuff he occasionally does: Write for magazines (currently mainly Heise's iX) or in my Blog, publish a podcast (2 Developers Down Under) with my friend Mark Mandel from Melbourne and since 2007 he flies small, single-engine airplanes around New Zealand and sometimes Australia, currently working on his Commercial Pilot License.
Interview transcript
Michael: Welcome back to the show. I'm here with Kai Koenig, and he’s joining us from New Zealand where it's just after 6:00 a.m. which is very dedicated of him to the ColdFusion community. And we're going to be talking about some tools for improving your ColdFusion code quality, and we'll look at why this code quality matter, and what it means in practice. And we'll look at some different things you can do to measure your code quality without running the code.
And also, we’ll examine why there are more tools in other languages than CFML in this field, and what Kai is doing to remedy this with the C.F. Lindt project and we’ll dig into that in a bit more detail. And if you haven't met Kai, he's been in the ColdFusion community for nearly 20 years now. I think I met him out a C.F. Europe event many years ago. And he works for [inaudible] [00:53] in Wellington, New Zealand. And he doesn't whole a bunch of things from ColdFusion, to Flex, to Java, all kinds of stuff; maybe we'll talk about that a bit later. So welcome Kai.
Kai: Welcome Michael, thanks for having me, good morning.
Michael: Yes, good… well evening for me, but morning for you. So, let's just start off because people may not have thought about this at all. Why does code quality matter?
Read more
And to continue learning how to make your ColdFusion apps more modern and alive, I encourage you to download our free ColdFusion Alive Best Practices Checklist.Because… perhaps you are responsible for a mission-critical or revenue-generating CF application that you don’t trust 100%, where implementing new features is a painful ad-hoc process with slow turnaround even for simple requests.What if you have no contingency plan for a sudden developer departure or a server outage? Perhaps every time a new freelancer works on your site, something breaks. Or your application availability, security, and reliability are poor.And if you are depending on ColdFusion for your job, then you can’t afford to let your CF development methods die on the vine.You’re making a high-stakes bet that everything is going to be OK using the same old app creation ways in that one language — forever.All it would take is for your fellow CF developer to quit or for your CIO to decide to leave the (falsely) perceived sinking ship of CFML and you could lose everything—your project, your hard-won CF skills, and possibly even your job.Luckily, there are a number of simple, logical steps you can take now to protect yourself from these obvious risks.No Brainer ColdFusion Best Practices to Ensure You Thrive No Matter What Happens NextColdFusion Alive Best Practices ChecklistModern ColdFusion development best practices that reduce stress, inefficiency, project lifecycle costs while simultaneously increasing project velocity and innovation.√ Easily create a consistent server architecture across development, testing, and production√ A modern test environment to prevent bugs from spreading√ Automated continuous integration tools that work well with CF√ A portable development environment baked into your codebase… for free! Learn about these and many more strategies in our free ColdFusion Alive Best Practices Checklist.