Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 6 Next »

Agenda

Est timePurposeActionNote taker
5mnsEffectiveness & efficiencyReview this proposed agenda.Nimisha
25mns

Context-switch into DDD mindset.
(review for some, new for some)
Remember and align on terms.

We will read and discuss the following pages from DDD Reference:

  • p 2 Bounded Context
  • p 29 Context Map
  • pp 39-46 Section V
Robert
10mnsReview Domain Vision StatementedX Domain Vision StatementDave
25mns

Identify Domain Use Cases


5mnBreak

20mnsComparison of modelsCompare identified "use cases" with our previously identified "jobs"Shelby
40mnsCore Domains Diagram
5mnBreak

30mnsContext Map?George
15mnsIdentify Next Steps
Nimisha

Notes:

  •  DDD Reference Notes:
    • Bounded Context discussion (p2):
      • Large codebase, multiple models is inevitable.
      • Organization and Architecture reflect each other.
      • Illustration:
        • What is a course?  What is a course run?
          • LMS: XBlock content.  Not strong association between runs.
          • ECom/Discovery: What it calls a course and what it knows about a course is different.
    • Ubiquitous Language (p3?)
      • Important that all stakeholders are involved.
      • Language must be consistent within a bounded context.
      • Hopefully, the same language will be used across contexts when and where a concept applies.
      • Document this and help with onboarding: how and where is this captured?
      • Someday get clear on how much we are willing to update code to match changes in Ubiquitous Language.
      • Do not allow the same word to mean two different things in the same in the context.
    • Core Domain (p40):
      • We define Core as Core for today, and not necessarily the future.  Could evolve as the company pivots.  Might help us make faster progress on deciding.
      • Questions about whether core could change?  Or maybe the pure core would never change?
      • Assign best developers here.
    • Generic Subdomains (p41)
      • Discern your core.  Dusting off what you first think is core might end up being a generic subdomain, in which case you might choose something off-the-shelf.
      • Notifications is an example.  Payments is an example.
      • Don't assign best developers here.  They won't pick up core domain knowledge.
    • Supporting
      • Supports core but not generic.
    • Example:
      • Game Engines might be generic and you might be required to do your own specific game engine if your use cases are more specific and required.
        • It doesn't make sense for a small company to make their own generic game engine. Can't compete on breadth of features.
        • It may make sense for them to do something very specialized to their game.
  • Review Domain Vision Statement
    • Was made by Engineers
    • Takes strong stances on revenue, open source (last two paragraphs)
    • Reads as high level business strategy, not clear how it relates to arch in core
      • According to DDD, this is appropriate, and there's another doc that goes with this to bridge the two.
    • Trickiness of defining Core is understanding the business strategy better.
      • What's the timeline of "Vision Statement"?
      • Expectation that the Core will evolve over time.
      • Do we focus on only what we're doing now instead? Example of revenue.
        • There's still some core of edX that won't radically change regardless.
        • The elevator pitch for edX doesn't need monetization details.
        • Is Open Source core in that sense?
  • Identify Domain Use Cases
    • User types:
      • Learners
      • Educators
      • Admins (wants reports on their students)
      • Researchers
    • Educators (what they need, from Shelby's presentation) + Researchers
      • Support Educators
        • Easy Authoring and Administration of Courses
        • Communities of Practice
        • Actionable Data and Feedback (Insights + Data package)
      • Teaching at Scale
        • Course Design
        • Education Tools
        • Supporting Learners (Community and Mentorship)
      • Experimentation
    • Learners
      • Discovery: Find the right course/program to help them achieve their goals
      • Achieve Learning Outcomes
        • Rigor/quality of instruction
      • Support through their learning pathway – progress, messaging, social
      • Proof of Learning, credentials/certifications
    • Admins
      • Actionable Data and Feedback
        • What are my students doing 
        • Am I getting my money's worth
      • Setting up edX for their org
        • Curation
        • Integration


  • No labels