TE
TechEcho
Home24h TopNewestBestAskShowJobs
GitHubTwitter
Home

TechEcho

A tech news platform built with Next.js, providing global tech news and discussions.

GitHubTwitter

Home

HomeNewestBestAskShowJobs

Resources

HackerNews APIOriginal HackerNewsNext.js

© 2025 TechEcho. All rights reserved.

Ask HN: Better tools for the software requirements / scoping phase?

181 pointsby castdoctorover 6 years ago
Many software projects seem fail or go over-budget from poorly defined or changing specifications. It seems we have excellent tools to manage the delivery of software, but less so at the design/scoping phase. What are your thoughts of using better tools that leverage, say, Domain Driven Design or BDD (Behaviour Driven Development) that would engage end-users early on?

37 comments

mjulover 6 years ago
The underlying assumption with requirements is often not stated explicitly: that people _can know_ everything in detail, in advance.<p>If that is the case, surely we can find better ways to uncover the requirements, and better tooling will help solve the problem.<p>Experience tells me that people don’t know everything beforehand. Thus the key assumption is not valid.<p>Then the question we should be asking is: how do we most efficiently bring people to where they discover and understand the requirements?<p>Experience tells me people are much better at giving concrete, specific feedback to a running system than to an abstract requirements document.<p>Hence iterative development.<p>In essence requirements are not a document by a process.
评论 #18057693 未加载
评论 #18056638 未加载
评论 #18057684 未加载
评论 #18056125 未加载
评论 #18058773 未加载
评论 #18056952 未加载
评论 #18056816 未加载
评论 #18056872 未加载
评论 #18056228 未加载
hyperpalliumover 6 years ago
This was the inspiration for &quot;Extreme Programming&quot;:<p>You make a minimal cost mockup ASAP, for the client to try out, to see if it&#x27;s what they wanted. Clients can&#x27;t appreciate requirements, so (like, actual) architects make a scale model first.<p>The alternative, of doing requirements as a separate phase, was ridiculed as the &quot;waterfall model&quot;. In reality, there&#x27;s interactions between the so-called phases of req, spec, design, code, test, maintain etc.<p>The truth is that understanding the problem is most of the work - not just for the programming problem, but for the business problem. It&#x27;s just difficult. And when the world changes, you just have to change with it. If you try to anticipate what&#x27;s next, you&#x27;ll invariably get it wrong.<p>Because the world is changing faster, software develoment has gone from beautifully engineered software that just keeps working, to slapped together solutions, and a fulltime team that runs alongside, slapping patches on patches, continuously.<p>What&#x27;s the point of spending the time and money on beautiful engineering, if it&#x27;s going to be scrapped tomorrow anyway (or even before it&#x27;s finished)?<p>The only hope is for tools, libraries, frameworks and languages, that address lower levels of abstraction, that change less frequently. This isn&#x27;t all good, but the JVM is one example.
评论 #18056922 未加载
评论 #18055631 未加载
duncanawoodsover 6 years ago
You might be interested in <a href="https:&#x2F;&#x2F;thorny.io" rel="nofollow">https:&#x2F;&#x2F;thorny.io</a> - an interactive notebook for decision-making.<p>It&#x27;s purpose is to capture design-rationale and bring it to life so that as you refine your reasoning, the changes ripple through your decisions. It can help communicating complicated design decisions that can be awkward to capture in prose.<p>It&#x27;s intended to be very low-friction so more like markdown than old requirements management or decision support systems. My dream is that it can help us tackle decisions so complicated we usually give-up e.g. when multiple decisions impact each other.<p>I am currently in beta and I&#x27;d love to talk to anyone interested in the topic. Please drop me a line at duncan at thorny.io.
评论 #18055883 未加载
评论 #18056890 未加载
评论 #18056820 未加载
mienskiover 6 years ago
As someone that spends most of their days at the design&#x2F;scoping phase, then watching the product go into development where it encounters constant misunderstandings and gotchas that the customer never told us about or never realised themselves, I completely agree that there is a huge disconnect between the scoping and requirements phase and the build phase.<p>I almost have guilt over feeling like my work of design and scoping is effectively useless to a developer, all my mockup layouts have to be built ground-up, my requirements aren&#x27;t actionable in any way unless they feel like reading them (I try to keep them as succinct as possible, but the nature of working for clients also means I have to be somewhat specific so that people know when they should actually pay us). I&#x27;ve looked into things like Cucumber (<a href="https:&#x2F;&#x2F;cucumber.io&#x2F;" rel="nofollow">https:&#x2F;&#x2F;cucumber.io&#x2F;</a>) so that my requirements can actually be compiled as tests, but adoption is slow and arduous, and all I&#x27;m really doing is adding more work to a dev.<p>My latest line of thinking is that I need a way to show the user interface, and then the data flow and logic all the way back through the system (usually a back-end DB or a customer legacy system). It&#x27;s vital that these are presented together, hence my current process is interactive mock-ups built in Sketch (<a href="https:&#x2F;&#x2F;sketchapp.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;sketchapp.com&#x2F;</a>) and hosted on Invision (<a href="https:&#x2F;&#x2F;www.invisionapp.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;www.invisionapp.com&#x2F;</a>) which allows the customer and developer to click around and see it on a mobile screen so they really get a feel for it. Finally I couple that with a BPMN diagram which has swim lanes not just for the traditional system swim lanes, but also for a user (i.e. User taps Submit) and for a user interface (i.e. shows the mockup screen that is displayed), and then the logic flows down through the diagram. (e.g. User, User Interface, Mobile App Logic, Server Logic, Server DB, etc.)
评论 #18055611 未加载
评论 #18059307 未加载
ian0over 6 years ago
Not a software tool but I was recently introduced to the design-sprint[1] methodology from google and found it helped a lot with the requirements gathering and speccing phases. It was also light and easily implementable - they have some resources there too.<p>[1] <a href="https:&#x2F;&#x2F;designsprintkit.withgoogle.com&#x2F;" rel="nofollow">https:&#x2F;&#x2F;designsprintkit.withgoogle.com&#x2F;</a>
评论 #18057812 未加载
andymoeover 6 years ago
We do this thing we call Discovery &amp; Framing at the kickoff of a new project. It usually lasts 3-6 weeks and involves design, product, engineering and someone with the power to make decisions on the spot. We call this role a product owner.<p>It’s a good way to get stuff out of folks heads, validate the problem and solution with users, and end up with some stuff for everyone to execute on by the end of the process. You can google the term for more detailed descriptions.<p>As for tools, we’ve been having success with real time board, and pivotal tracker (maybe gives away where I work) and of course a ton of sticky notes.
评论 #18062687 未加载
fbonawiedeover 6 years ago
I&#x27;m a co-founder of a Swedish startup, and we have built a tool targeting product owners and product managers. It aims to eliminate endless email threads and disconnected workflows that are common in product development. It sort of replaces Word, Google docs, and Confluence and integrates with Jira and Slack.<p>I would be happy to give you a quick demo!<p><a href="https:&#x2F;&#x2F;www.delibr.com&#x2F;demo" rel="nofollow">https:&#x2F;&#x2F;www.delibr.com&#x2F;demo</a>
评论 #18056731 未加载
评论 #18057096 未加载
contingenciesover 6 years ago
Requirements are almost never perfectly specified. One of the most substantial and hard-learned parts of good systems design is automatically pre-empting, as far as reasonably possible, the probable range and depth of requirements scope shifts over the project lifetime. (Critically, that includes the 90% of a project&#x27;s lifetime which is post-development maintenance.)<p>In short: if you have good people it shouldn&#x27;t matter! Experienced people will extend the assumed scope beyond the stated requirements without being asked, and either do so efficiently within the resources available to the project or bring an appropriate level of attention to the limitation before it becomes an issue.<p>The somewhat less PC and far snarkier explanation, in the immortal words of twitter: <i>Don&#x27;t pick the right tool for the job, pick the right framework which secures you extra work for being a tool.</i> - @iamdevloper (via <a href="http:&#x2F;&#x2F;github.com&#x2F;globalcitizen&#x2F;taoup" rel="nofollow">http:&#x2F;&#x2F;github.com&#x2F;globalcitizen&#x2F;taoup</a>)
mysterydipover 6 years ago
I recently took a model-based systems engineering course that opened my eyes to some helpful methods.<p>Use UML, SysML, etc to diagram out your requirements (starting at high level at first, more granular as the system matures). Now build a high-level model of your system design (software and hardware if required). Match parts of your system to the requirements. This lets you see gaps in two directions: requirements you haven&#x27;t addressed (because they aren&#x27;t connected as &quot;satisfied by&quot; anywhere on your model), and questions to ask for more detail on a given requirement that could drive the design.<p>As others have said, there will always be late requirements that change things, so it won&#x27;t resolve those. It can, however, show stakeholders how much changing a requirement can cost in terms of rework&#x2F;time by showing how the model has to change to accommodate.<p>The caveat with this is: the model needs to reflect your actual design, and you need to keep it up to date. The times I&#x27;ve used it so far it has been a useful exercise.
评论 #18056850 未加载
BjoernKWover 6 years ago
I agree that what you describe is a huge problem. I&#x27;m not so sure though if that problem can be alleviated by additional tooling. More often than not the cause of this is defective processes and assumptions rather than deficient tools.<p>DDD, ubiquitous language and bounded contexts in particular, can be enormously helpful with defining better requirements.<p>I&#x27;m not so sure about BDD though in this context. While the notion of the customer &#x2F; product owner writing specifications in this format in a way developers can use these specifications to test their code sounds great at face value I have yet to see a project where this is done consistently and continuously.<p>Moreover, some types of requirements can be better explained by using diagrams or UI mockups, which doesn&#x27;t really fit the BDD paradigm.
评论 #18055859 未加载
beatover 6 years ago
It&#x27;s not free, and it&#x27;s not simple, but Aha (<a href="https:&#x2F;&#x2F;www.aha.io" rel="nofollow">https:&#x2F;&#x2F;www.aha.io</a>) can be very helpful in figuring out product.<p>Engaging end users is a problem from a couple of directions. First, the very idea of &quot;end user&quot; - you need to engage <i>customers</i>, not end users. (Take Facebook, for example... you&#x27;re not the customer, you&#x27;re the product. If you build something for Facebook, your customer is Facebook, not Facebook&#x27;s users.) This situation isn&#x27;t exactly unusual. In this case, it&#x27;s the customer&#x27;s responsibility to gather feedback from end users - and put you in the feedback loop, as needed.
jdswainover 6 years ago
There is a class of tools for this called Requirements Management. They tend to be expensive and clunky tools in my experience, but I haven&#x27;t used one for quite a few years. Ones I have used are Rational Requisite Pro (IBM) and Doors, which is now apparently an IBM Rational product too. I&#x27;ve worked on a project that used Doors for requirements management but also requirements traceability, a somewhat tedious task that would let us look from a requirement and identify all development documentation that implemented that requirement and eventually to code if required.<p>From an logical point of view I think it makes a lot of sense to start from clearly documented requirements, then work forward to design, implementation, and testing with links back to each requirement. I don&#x27;t know how testing (higher level than unit testing) can really be effective unless they have requirements documents to use as their starting point. Use Cases go some of the way to providing this information but tend to be a bit less formal. Agile methodologies tend to be less formal than older methodologies that emphasised this kind of process more. A lot of Agile is good, but it does also tend to forget lessons from the past.
jimdukover 6 years ago
People build tools for use. Software projects are an example of this. A lens I find helpful is to view a software project as a &quot;process (or game) of transforming shared and individual understanding (or belief), into a tool or artefact&quot;. The project falls short if the understanding is not valid or the tool is poorly built or if the tool doesn&#x27;t encapsulate the understanding or if circumstances change and the tool becomes less useful.<p>Transferring valid understanding into the final artefact is a key constraint in many projects (reading Goldratt and thinking of this transfer of understanding as a constraint was helpful for me)<p>There are many ways to fail. Some of the traditional ways to succeed are<p>i) rely on an individual who really understands the desired tool, and who has the authority and skill to communicate and be the final arbiter (including sometimes to write it all themselves). Sometimes this can be also done by a small group.<p>ii) write a really clear, well-written, very hard to misinterpret document and get professionals to develop and test this system (before the document goes significantly out of date)<p>iii) Run an agile process where the business can describe what they want in small pieces that can be delivered so quickly that little understanding is lost<p>Obviously what works is massive contextual, depending on the domain, funding, resource reqts etc. (Glen Alleman is good on this)<p>So I would argue &#x27;good software tools for requirements&#x27; are critically dependent on your approach for how you are going to turn &#x27;understanding&#x27; into a &#x27;system&#x27;, and you don&#x27;t want to worry too much about them until you are happy with your approach. At that point you can start building your &#x27;meta-tools&#x27;.
a13nover 6 years ago
I run Canny (<a href="https:&#x2F;&#x2F;canny.io" rel="nofollow">https:&#x2F;&#x2F;canny.io</a>), which is a tool that software companies use to keep track of feature requests from their customers.<p>One awesome thing you can do is ping everyone interested in a feature, and ask them how they want it to work. See it in action here: <a href="https:&#x2F;&#x2F;feedback.canny.io&#x2F;feature-requests&#x2F;p&#x2F;tags" rel="nofollow">https:&#x2F;&#x2F;feedback.canny.io&#x2F;feature-requests&#x2F;p&#x2F;tags</a>. (Scroll down to Sarah&#x27;s comment on July 20.)<p>Whenever we&#x27;re thinking about building a feature, we ping all the stakeholders. This gives us solid context on how they want it to work, which helps us define our MVP. If we need to follow up for more information, it&#x27;s easy to do that via email &#x2F; Intercom.<p>Hope this doesn&#x27;t come off as salesy – I really felt it was relevant.
ryanmarshover 6 years ago
The solution to a “complex” problem is only knowable after the fact, versus merely complicated problem which is knowable before the fact. Any sufficiently useful computer program is typically “complex”, though not always.<p>That said it is still incredibly helpful for everyone to agree on what we’re building in the present iteration&#x2F;sprint. You mentioned BDD which can be very helpful when paired with a team practice such as Example Mapping[0].<p>Other practices such as DDD can help you bound the problem and define it. Also there are some helpful lessons in Feature Driven Design.<p>Source: I teach BDD workshops for a living<p>[0] <a href="https:&#x2F;&#x2F;cucumber.io&#x2F;blog&#x2F;2015&#x2F;12&#x2F;08&#x2F;example-mapping-introduction" rel="nofollow">https:&#x2F;&#x2F;cucumber.io&#x2F;blog&#x2F;2015&#x2F;12&#x2F;08&#x2F;example-mapping-introduc...</a>
Redsquareover 6 years ago
You can engage all stakeholders via a series of eventstorming sessions <a href="http:&#x2F;&#x2F;ziobrando.blogspot.com&#x2F;2013&#x2F;11&#x2F;introducing-event-storming.html?m=1" rel="nofollow">http:&#x2F;&#x2F;ziobrando.blogspot.com&#x2F;2013&#x2F;11&#x2F;introducing-event-stor...</a>
评论 #18055629 未加载
motohagiographyover 6 years ago
I&#x27;ve been doing a variation of this for security, as it&#x27;s the main need that requires abstraction-on-down definition, and it doesn&#x27;t translate well into agile environments where developers are designing solutions. (qtra.io, in private beta, so no free experience yet)<p>The fit problem I&#x27;m having is getting technical threat hunters who populate the market to think about risk and security design, or product&#x2F;project managers to reason even high level about a domain they delegate to technologists.<p>Still iterating for fit, but so glad there is a thread of people thinking about architecture.
crdoconnorover 6 years ago
I got frustrated with cucumber and cucumber-esque tools for doing BDD so I built my own which were optimized for programmer usability (strict type system, inheritance built in, sane syntax, etc.):<p><a href="http:&#x2F;&#x2F;hitchdev.com&#x2F;hitchstory" rel="nofollow">http:&#x2F;&#x2F;hitchdev.com&#x2F;hitchstory</a><p>The time when it was most useful as a &quot;BDD tool&quot; was when I was working with an extremely technical stakeholder who was proposing behavior in a command line tool he wanted.<p>I simply wrote &#x27;tests&#x27; that described the command line tool&#x27;s behavior and showed the YAML to him. He corrected the mistakes I&#x27;d made by misinterpreting his original requirements and then I built the tool to that spec and when it passed I was confident I&#x27;d nailed his requirements.<p>QA picked up bugs afterwards but they were all either (quickly rectified) mistakes he&#x27;d made in the spec or environment issues. I had zero spec&lt;-&gt;programmer communication issues even though (and here&#x27;s the crazy part) <i>the domain was very complex and I didn&#x27;t understand it</i>. It had to do with a highly customized software system I didn&#x27;t understand which enacted some sort of financial process which I also didn&#x27;t understand.<p>Cucumber can do this in theory, but in practice the spec is not sufficiently expressive and the stories end up being ridiculously, unusably vague. Unit tests could also do this in theory I guess, but good fucking luck getting a stakeholder to read them even if you do manage to write them &quot;readably&quot;.<p>I&#x27;m taking this process a step further. Although these YAML specifications were useful for me in the past to collaborate with stakeholders they&#x27;re still not amazingly readable. For instance, the &quot;YAML inheritance&quot; makes it easy for programmers to maintain but harder for non-technical stakeholders to understand.<p>Instead of sacrificing maintainability for readability I created a process to easily generate readable stakeholder documentation from the &#x27;YAML tests&#x27;. I used this in the libraries on the website above to generate always-in-sync-and-still-highly-readable documentation.<p>I think this could be used to essentially write low level &quot;unit&quot; tests which generate documentation which stakeholders can interpret (e.g. defining the behavior of a complex pricing algorithm) and use that to get a quicker turnaround on understanding, defining and modifying desired behavior in complex domains.
tximeover 6 years ago
If you don&#x27;t mind a shameless plug, we&#x27;d be happy to invite you on Txime, a collaborative webapp to conduct DDD and especially event storming sessions. <a href="http:&#x2F;&#x2F;www.txime.com" rel="nofollow">http:&#x2F;&#x2F;www.txime.com</a> We&#x27;re in beta but opening soon.
shussonover 6 years ago
In my experience focusing on the tools usually ends up failing projects or going over-budget. e.g &quot;we don&#x27;t have a product yet, but look at all these shiny cucumber tests!&quot;. I think a good start is to have someone who is very user focused in the team.
nickjjover 6 years ago
I just use a whiteboard or paper. Nothing beats it IMO because at this stage you want to create a brain dump and chances are you&#x27;ll be making a lot of changes.<p>With most programs, you&#x27;ll spend half your time battling its UI and trying to get around limitations.
sailfastover 6 years ago
Many people have said this but here goes anyway: The tooling will not help you better define the specifications. The tooling will not help you manage changing specifications. You can cover all the bases easily in a free Github project (Edit: pick your web-based tool, basically) without too many issues.<p>I would argue that the reason things get called out as poorly defined or change is because risks are not addressed early, and hypotheses are assumed to be theorems.<p>Make sure your teams test the main assumptions early, with actual code if at all possible. That will call out why your stories aren&#x27;t clear enough.<p>Tools are useful, but they won&#x27;t solve your problem.
bpizziover 6 years ago
Those days I just sketch wireframes in a Google Slides presentation.<p>Bonus point for the interactivity: I can share the URL for remote work sessions, and the stakeholders on the other end of the line can see me create&#x2F;adapt wireframes and notes in real time, while I&#x27;m explaining everything on the phone (using anonymous access for those not logged into &#x27;The Google&#x27;).<p>Google Docs has version management since this year (I think), so I can pinpoint the evolution of specifications over the time. When I&#x27;m done I&#x27;ll just export a PDF and attach to a &quot;Spec done!&quot; mail to everyone.
sigsergvover 6 years ago
This is very advanced topic and I think (almost) all “end-users” are absolutely not ready to embrace it. You cannot be completely sure that you and “end-user” are thinking about the same subject.
agentultraover 6 years ago
I think it depends on the problem domain. In high-risk or regulated industries having requirements and specifications is a prerequisite to shipping. There are plenty of good sources for finding the standard expected formats out there. If you&#x27;re an IEEE member you&#x27;ll find the ISO requirements and specifications templates in the library.<p>Doing requirements gathering isn&#x27;t an inherently bad process to adopt even in non-regulated settings. However I believe many developers will have a negative reaction due to prior experiences with, or having heard about, the waterfall method. The key to remember is that requirements don&#x27;t, and shouldn&#x27;t, have to come with an estimate. Great requirements demonstrate a thorough understanding of the problem. They&#x27;re written from the perspective of the end-user.<p>Specifications are the dual of requirements and are what drive the implementation that solves the stated problem. Specifications is something I think we need to get better at. We some unit testing, some integration tests, and occasionally end-to-end user tests... some few to property tests; but rarely do we write formal, verifiable specifications in a modelling language that can be checked with a model checker. Rarer still do we write proofs as part of our specifications.<p>We often elide specifications or we do the minimum necessary to assure correctness. This is to the detriment of your team on a larger project. How do you know your designs don&#x27;t contain flaws that could have been avoided? How much time are you spending before you realize that the locking mechanism you chose and shipped has a serious error in it that is causing your SLO&#x27;s to slip?<p>For requirements I just use plain old Markdown with pandoc. For specifications I use a mixture of Markdown and TLA+. I use TLA+ for the hard parts of the system that we&#x27;re unsure about and require correctness for. The rest of the specifications that aren&#x27;t as interesting I simply use prose. It&#x27;s a matter of taste but it does require an intuition for abstraction... when to do it and how to think about systems abstractly.<p>We could definitely use better tools for TLA+-style specifications, btw. Maye more libraries that can translate TLA+ state machines into the host language so that we can drive them from our integration tests, etc. Better IDE tooling. Better training.
lifeisstillgoodover 6 years ago
I have been mucking about with the idea of textual prose discussion documents, which hyperlink markdown style to usecases, which link to tickets in Jira or somesuch.<p>then as the document is discussed and altered by the owner the use cases alter and flow<p>It&#x27;s just trying to keep a prose discussion in line with everything else in dev friendly manner (it can be stored in the docs folder in git and be generated onwards etc)<p>still playing
flargover 6 years ago
Wireframes for UI design alongside UML for enterprise data models and process flows, and finally good old truth tables work best in my experience. They work to bridge the gap between business and development. You&#x27;ll never get 100pc coverage but you&#x27;ll get a lot of the way there.
tnoletover 6 years ago
I loved reading &quot;User Story Mapping&quot; and putting it to use. It really changed how I worked. Highly recommended. <a href="http:&#x2F;&#x2F;shop.oreilly.com&#x2F;product&#x2F;0636920033851.do" rel="nofollow">http:&#x2F;&#x2F;shop.oreilly.com&#x2F;product&#x2F;0636920033851.do</a>
smartmicover 6 years ago
Coming back to the question: One possible helpful tool is Doorstop (<a href="https:&#x2F;&#x2F;github.com&#x2F;jacebrowning&#x2F;doorstop" rel="nofollow">https:&#x2F;&#x2F;github.com&#x2F;jacebrowning&#x2F;doorstop</a>).<p>I like the approach to embed requirements in source code (management).
cosinetauover 6 years ago
Aren&#x27;t there testing frameworks that were supposed to help solve this problem?<p>Maybe you could engage customers qualitatively, and translate that information into software requirements and acceptance tests? I&#x27;m not entirely clear how you want to engage these kinds of users.
gbtwover 6 years ago
We did a lot with jstd and used doors succesfully <a href="https:&#x2F;&#x2F;www.ibm.com&#x2F;us-en&#x2F;marketplace&#x2F;rational-doors" rel="nofollow">https:&#x2F;&#x2F;www.ibm.com&#x2F;us-en&#x2F;marketplace&#x2F;rational-doors</a>
tmalyover 6 years ago
I experience issues with poor requirements everyday. The single biggest problem I see is that the people writing the requirements have no idea how to write them. We do not need a tool as much as we need better training.
bartkappenburgover 6 years ago
I always refer people to this analogy on the problem of estimation in software projects, I think it&#x27;s pretty spot on: <a href="http:&#x2F;&#x2F;qr.ae&#x2F;TUGpbW" rel="nofollow">http:&#x2F;&#x2F;qr.ae&#x2F;TUGpbW</a>
DanielBMarkhamover 6 years ago
Technical coach here. This is a passion of mine. I&#x27;ve seen far too many teams waste far too much time with horrible, horrible backlogs and tooling systems -- usually set up with the most sincere good intentions, by the way. I care so much about it I wrote a book on managing project information. The key example, repeated throughout the book, is a small team meeting folks and starting to make stuff people want. (Obligatory link: <a href="https:&#x2F;&#x2F;leanpub.com&#x2F;info-ops" rel="nofollow">https:&#x2F;&#x2F;leanpub.com&#x2F;info-ops</a> )<p>I believe if you can get the small team scenario working over-and-over again scaling will work itself out. So far I have no reason to believe this isn&#x27;t the case -- and I&#x27;ve applied the principles in the book both to functional coding and program management.<p>mjul&#x27;s comment is the key one: you can&#x27;t know everything before you start. That doesn&#x27;t mean you can&#x27;t know <i>anything</i>. It means that there is a &quot;progressive elaboration&quot; that has to happen on an as-needed basis. Otherwise you&#x27;re stuck either not knowing enough to get going -- or having created a monster or a tools&#x2F;information system that ends up running the project instead of the team.<p>There are some sanity checks for whatever backlog&#x2F;requirements system you are using. Instead of my continuing to pitch, I&#x27;ll just list the things that your system should do no matter what kind of system you have.<p>- Handle whatever detail is needed before actual development happens.<p>- Be able to &quot;flip-around&quot; and start from scratch within an hour or so. (And &quot;starting from scratch&quot; means beginning with nothing and ending with the team starting coding) While keeping all that detail in test 1.<p>- Be reusable with other teams doing similar work. A backlog&#x2F;requirements system can&#x27;t make work fungible, but it can enable better conversations in other teams without being a burden.<p>- Limit meetings around organization to under an hour or so. Yep, you gotta have those &quot;meta&quot; meetings from time-to-time and talk about things like release plans. But they shouldn&#x27;t take over your afternoon.<p>- Help the larger organization (if there is one) learn and grow over time. Orgs learn from the bottom-up. Good tools should facilitate this learning.<p>- Drive directly to acceptance tests. Good backlogs are testable. Things shouldn&#x27;t be in there that don&#x27;t drive tests.<p>- Have controls in place to prevent abuse. As soon as you create some tool for the requirements&#x2F;scoping phase, somebody is going to go all architecture-astronaut and overuse it. There has to be controls to prevent this from happening. The tool should <i>facilitate</i> the work of understanding and scoping, not <i>replace</i> it. (I think even a lot of tools vendors get confused on this one).<p>I even wrote an analysis compiler that demonstrates all of this as part of writing the book. So if you think all of this is impossible -- happy to do a demo.<p>There are a few other testable criteria for whatever your requirements&#x2F;backlog system is, but that should be enough to get you started deciding whether some system is better or worse than another system.
slaymaker1907over 6 years ago
I really like TiddlyWiki since it makes it easy to link everything together and organized.
j45over 6 years ago
You may like a product roadmapping tool like Aha.io
wasd884over 6 years ago
Better colleagues with better brains.