Versions Compared

Key

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

...

  1. (REST) Scripts & Processes endpointhttps://github.com/DSpace/Rest7Contract/pull/17
    1. How do we move this forward? In our Jan 24 meeting, Tim noted a risk of "scope creep" with this feature suggestion. This idea has been tabled since then.
    2. In July 25 meeting, Atmire said they'd come back with notes on the proposed backend implementation.
  2. Managing Authorization info in Angular UIHow to pass Authorization rights (i.e. logged in user's access rights) from REST API to Angular?  See for example: https://github.com/DSpace/dspace-angular/issues/393
    1. Can this be achieved via passed HAL "_links" (e.g. the existence of an "edit" link in REST response means you must have Edit rights)?
    2. In July 25 meeting, we noted this probably cannot be resolved with just one simple solution. May need to look at different options for different scenarios
      1. Also likely to need to store/cache a user's Groups in UI layer, as some areas (e.g. Administrative) require knowledge of user group membership
  3. Initial Performance Testing from Chris.
    1. https://cwilper.github.io/dspace-perftest/
  4. (REST Contract) Edit Homepage News: https://github.com/DSpace/Rest7Contract/pull/45
    1. Delayed until after Preview release. General agreement (in meeting on March 21, 2019) that storing HTML in metadata fields is not really ideal behavior.  Metadata (from a librarian standpoint) tends to be free of format-related markup (as that allows for easier sharing, understanding of metadata.  Currently Community & Collection homepage information is HTML-based and is stored in metadata that is appropriate for a minor subset of information (like the title) but it is better to move large/rich text to bitstreams.  
    2. Proposal here is to consider storing HTML-based markup (for Site, Community & Collection homepages) in Bitstream(s) associated with the object in question.  May allow for more CMS-lite behavior in the future
    3. Timeline for this is uncertain.  Possibly in 7 or 8. May depend on how/whether it can be scoped.
  5. Concurrency in DSpace 7 (or 8).  What do we want to do when multiple editors are editing the same object?  Needs further analysis regarding implementation details
    1. We've decided (in meeting on March 7, 2019) to use ETags to implement concurrency. REST Contract notes on ETags: https://github.com/DSpace/Rest7Contract#etags--conditional-headers
    2. ETags only update of the two fields match. If someone edits first, your edit would fail and you would get a fail response (422?)
    3. ETags seems to have broader support in other REST APIs.  Recommended also by both Art and Andrea.
  6. Improve/Re-enable End To End (e2e) Testing. Could there be opportunities to use Travis CI + Docker Compose for testing of Angular?? https://github.com/DSpace/dspace-angular/issues/453#issuecomment-519672141

Notes

  • Detailed walkthrough / discussion of DSpace 7 Estimation Process
    • Talked through details on wiki page around the overall process itself
    • KEEP IN MIND: This first time around we are only estimating tasks that are well defined.  Anything in the Development Planning Spreadsheet marked currently as "NEEDS MORE INFO" is not included in this initial estimation process.  We will work to better define those tasks in coming weeks, and add them to a second round of estimation.
    • Walked through the first REST API spreadsheet, talking about how the process will work for individual developers
    • Feedback on general process
      • Since we don't have a specific developer pool or specific developers, this makes some estimates more challenging.  Usually you estimate based on known developer skill sets, etc
      • We don't even know if we have senior vs junior developers
      • Tim notes, maybe that's something we simply need to write into the estimates themselves (as assumptions).  More complex tasks may need to be assumed to be implemented by a senior developer (and we should clearly note that as part of the estimate).  Less complex tests should likely be estimated with a junior developer in mind, but if a senior developer picks it up, it could go much quicker than expected.
      • TODO: This is also something we can document better in our Estimation process Wiki page.  Tim will do so.
    • Feedback on spreadsheet
      • Andrea asks what about Integration / Unit Tests?  How do those get estimated
      • Tim says assumption was they'd be part of the development process, since we are doing TDD. But we could separate them into a third column, if it makes it more clear
      • Andrea says that we should either create a new column for creating tests, or ensure all estimators also have them in mind.
      • TODO: Tim will update our Estimation Process wiki page to make it clear that Tests need estimating too.  Will also think more about whether a new column seems like a good direction here.
    • Other Feedback
      • Lieven notes that we need to determine a way to eventually turn this into timelines
      • Tim agrees. Timelines depend on both estimates & resources though.  So, as we are doing estimates, we will also need to get a better handle on resources.  More resources can obviously decrease timelines, even if estimates show a lot of work left to do.
      • Lieven also notes that as we look at timelines, we need to be careful to consider dependencies among tasks.  Most tasks start at the REST Contract level, then REST implementation, then Angular design & implementation.   Need to ensure we schedule tasks to keep this in mind, as timelines can also be affected by dependencies that hold other development back / keep other developers from doing their work.
    • Lieven notes that Atmire team likes approach, feels they could start immediately (and provide feedback as they go).  Tim will create developer spreadsheets for anyone ready to start
    • Andrea notes that 4Science would also love to contribute. First few weeks of Sept might be different (per their own schedule), but week of Sept 16 currently looks open.
    • Andrea (and Tim) highlight we would also like to see if we can find estimators who are not  from Atmire or 4Science. This process works well even with developers who are unsure about their estimates.
      • ALL: Please consider whether you can chip in on some of these estimates as an estimator!  Review the spreadsheets, and let Tim know next week (Sept 5).
  • Next Week
    • Touch back on the Estimation Process.  Anyone have feedback or questions now that you've looked more at the spreadsheets?
    • Determine our list of estimators. Finalize who is doing estimates
    • Finalize the estimation timeline (will it take estimators 1 week? two weeks? three weeks?)
    • Start to schedule first Estimation Meeting(s) based on those timelines