Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

  •  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