Semantic MediaWiki
There's a lot of information on wiki.laptop.org. wikipedia:Semantic MediaWiki is an extension that lets you annotate existing wiki text and templates so that you can query and explore this information. Done right we get less duplication, more standardization, and easy information reuse.
mw:Semantic Forms is another extension that exploits SMW to let users edit template information in a form.
Where Semantics are being used
You can browse Special:Properties to see properties in use. You can use Special:Allpages to display Form: pages.
For tests
Many tests are using semantic annotations, so we can query for them. See Test cases 8.2.0 and Testcase Query Examples.
To display query results so that they look like the test case (green badge), use format=embedded. To display in some other format, someone has to create Template:Display_query_row_in_a_gray_box and use format=template | template=Display query row in a gray box
Some test results are also using semantic annotations, see TestResults 8.2.0.
Issues for Test cases
- Compare Tests/Sugar Control Panel/About Me/Color Change and Eben's Tests/Home view, latter uses different terminology: Justification (like Feature?), Actions (like Procedure?, Verify (like Expected results and pass criteria?
- Property:Build stream could usefully have service links to builds, diffs, packages, etc. This requires lowercase names (most URL's use joyride, not Joyride). See Property:Build stream for a discussion.
Structuring Test cases
We are using long titles that identify area, e.g. Tests/Sugar_Control_Panel/About_Me/Color_Change. Putting the organization in the name ensures test cases will appear in a useful order in generic queries.
Could also/instead use subcategories of Category:Test cases to identify the kind of test, but Semantic Forms has limited capability to assign categories. A query for a category will find things in its subcategories, so it's fine to have a detailed category hierarchy.
It might be possible to query for test cases "like" Tests/Sugar_*. to only show certain test cases.
Issues for test results
Test cases 8.2.0 is one page with many test results on it; so the page winds up having two values for Property:PassFail, "Pass" and "Fail". But to isolate each result, you would have to create a separate page for each combination of test case and build, e.g. TR_Build2230/Sugar Control Panel/Date & Time. That's a lot of pages to name, although Semantic Forms can automatically generate a unique page as you fill in a form]. Is there any reason to have semantics for each test result, when you can simply visit a page with the test results?
- TODO: figure out a generic way to have a link _Log a test result_ that when clicked goes to Form:Test_result and the wiki editor fills in a form that creates a test result linked to the original page. Then any page with a test on it can be "filled out" with test results that anyone can enter!
- Property:PassFail perhaps should be Type:boolean, just Pass true/false.
- Property:Trac bug number perhaps should be Type:URL, see discussion above.
For projects and tasks
see Form:Tasks and Form:Project, and their respective template pages Template:Task and Template:Project. We would like to use the Project, and Task forms to track projects, and to some extent replace the project database. The tasks template should be for small open tasks that will then be populated on aggregate pages based on various properties like priority and skill set required.
For deployments
All deployments have the deployment template on them. They also have the "edit with form" tab on the main page. This is seen on for example OLPC Peru. This information is aggregated on the page Deployments, using a semantic query. Also see Deployment query examples.
For activities
There is currently the Template:Activity page that is being used to keep track of general information about activities. In the Form:Activity there is also the template that allows for multiple bundle versions so that you can keep track of the last build that works with 656, even though it may not be the latest build.
We need to fix the main template so that it will also include a place for the .xo bundle
You can see an example query page Activity_query_examples
Adapting activities and their templates to use Semantic Forms would make it easier to
- maintain the Activities page
- show the status of activities in various activity packs
- query for things like activities that don't have a translation status.
For releases
Could put the information in Releases into separate sub-pages. Then Releases page can just be a query for the information. Then each ECO can query this information for its release instead of repeating it. Seems straightforward, unlike test cases there aren't hundreds of release pages.
- Greg's concern: identify and separate past (definite) releases from future (indefinite, in-planning) releases.
Reusing release values
wiki.laptop.org uses three methods to display a changing value like The release candidate on multiple pages without having to update each one.
- Mention one of the sub-templates of Template:Latest Releases, such as Template:Latest_Releases/stable
- latest release is ==> 13.2.11 || 2020-01-29
- Transclude a subpage with the information, such as Friends in testing/current image number or Friends in testing/current image stream
- current testing stream & release is ==> official & os860
- Use SMW's #ask or show function to display a property from a page, such as Property:Current image number for testing or Property:Current image stream for testing
- current testing stream & release is ==> {{#ask: Friends in testing/current image stream | ?Current image stream for testing=}} & {{#ask: Friends in testing/current image number | ?Current image number for testing=}}
- #show should also work... {{#show: Friends in testing/current image stream ?Current image stream for testing}} & {{#show: Friends in testing/current image number ?Current image number for testing}}
- As of 2008-08-07 this last semantic approach is implemented completely the wrong way, these should be generic properties Property:Stream and Property:Build associated with a descriptive page like Testing build or Stable release, not specific properties on specific page names. -- Skierpage 10:27, 12 August 2008 (UTC)
For events
Annotate events, jams, and meetings with [Property:Start date]], and then other pages can query to get a list or timeline of future pages. See the queries on Jams and Events#Upcoming events on wiki.laptop.org
- Also give events a Property:End date; this is optional for meetings and jams that are usually one day.
- Additional properties appropriate for events are Property:Has location city and Property:Has location country
- Can also use Property:Cooordinates to annotate where an event is. See, e.g. OLPC Switzerland/Meeting October Bern. Unfortunately it seems that displaying multiple events as markers on a map requires additional extensions.
To Do list
Trivial Fixes
- (ie just install something/ fix something that’s already installed)
- Semantic google maps
- Way to embed google maps in wiki with locations of projects/deployments and with links to appropriate wiki pages.
- Create a property of Type:Geographic coordinate and you get "service links" to Google maps for free (see e.g. [1], click the (?) symbol). However, displaying several such locations on one Google Map is tricky, you either need the Semantic Google Maps extension with SMW version 1.2 and/or the Google Maps extension (see example) -- Skierpage 10:26, 31 July 2008 (UTC)
Easy Fixes
- (ie just edit a little bit of code)
- Auto generate templates
- Make template an activity and edit with form
- Move around the <no include> tags
- But when empty it should show something
- Make a tag that says this is not semantic stuff
- Ignore semantics in a specific name space
- Alt text not working in templates
- Feature part of Tests/Sugar_Control_Panel/About_Me/Color_Change
- Add new types
-
- It's easy to add a property that has some built-in type (like [[Has type::Text]] and restrict it to certain values and maybe control its format.
- It's possible to add a new "linear" type that converts between different units , e.g. a Type;Area
- it's hard to add other kinds of types, it requires writing PHP code.
- -- Skierpage 10:42, 31 July 2008 (UTC)
- Time duration
- User
- Not sure what this means. If it's links to User:skierpage then maybe just create Property:User of type:page.
- Trac bug number
- This is available as Property:Trac bug number of type:Number. You should be able to use Service links and templates in query results to get this to display as a link. But numbers appear with a comma for the thousands separator. Could instead make it Type:URL and you use a template to fabricate the URL, but then it would appear as a long URL in query results. It might be possible to write PHP code to create a Type:Trac that displays appropriately, similar to how the <trac>4321</trac> code displays.
- Image
- Just some property of Type:Page (the default), in most cases SMW do the right thing and display the image .
- Template?
- Make the free text box larger.
- When creating a template, you should be able to create properties in that window as well as use already created properties.
- Way to 'prettify' links when used in SMW properties with a "Page" type.
- Example: Color Change instead of Tests/Sugar_Control_Panel/About_Me/Color_Change.
- See #Suggestions_for_test_cases. Maybe have a "Brief name" property and display that while linking to the full page name. Or, in queries use format=template and in the template use a parser string function to change the title from Tests/Sugar_Control_Panel/About_Me/Color_Change. Or, use categories to identify the hierarchy. You risk collision if the page title is just Color change, so you could have a little "TC" prefix, just TC/Color Change or a pseudo-namespace TC:Color_change
- Translating Property names
- Nathany on #cc
- When making a template add a more organized presentation of properties
Complex fixes
- (ie require creating a new extension)
- Something in between a list of specific allowed values and free text
- I want to be able to have the equivalent of an other field
- One approach: have two properties like Property:Version and Property:Version_more that you always display together, the first has restricted values, the other is text. Another is to use Type:Page and have pages for the allowed values. So not-allowed values "work", but stand out in red.
- Way to automatically email users who maintain pages
- Automatically populate data
- ex page last updated case
- SMW 1.1 can't query on or display such metadata. I think other extensions like DPL can.
- Way to pull %translated from pootle
- Could have a bot that gets this information and populates wiki pages with it.
Semantic annotations
The wiki has the wikipedia:Semantic MediaWiki extension installed, the thing to do is use it appropriately.
Successful rollout suggestions
- Deliver benefits early.
- To a casual editor, SMW is just more markup, more stuff to learn, an ugly factbox on pages, more "Semantic Web 3.0" hype. So find use cases that deliver obvious benefits early
- Don't create lots of properties and spend time annotating lots of pages until you have use cases for them. A person reading one wiki page after another does not need semantic annotations.
- It's fine to convert templates to make semantic annotations, since you get this "for free"
wiki.laptop.org issues
Use Template:SMW issue to note a problem on any page, it'll show up on the Property:SMW issue page.
Template conversion
- Use arraymap to turn lists of things into multiple property assignments.
- Use Semantic Forms... (not sure about it)
- Beware, people take advantage of wiki markup to stick all kinds of text inside templates. Maybe have an "fieldname extra info" field for arbitrary text.
Generic names
Should Property:Test objective be a generic name, or specialize it to Property:Test case objective ? skierpage's bias is to use generic names, but document on their property page what templates and pages use them.