Commit 0de52014 by Alison Hodges

Updates for DOC-83, new SQL table and event types for A/B testing

parent 3db4f43f
......@@ -10,14 +10,16 @@ Change Log
* - Date
- Change
* - 24 Mar 2014
- Added the ``user_api_usercoursetag`` table to the :ref:`Student_Info` chapter and the ``assigned_user_to_partition`` and ``child_render`` event types to the :ref:`Tracking Logs` chapter.
* - 19 Mar 2014
- Provided alternative formatting for the examples in the :ref:`Discussion Forums Data` chapter.
* - 13 Mar 2014
- Updated the :ref:`Student_Info` chapter.
* - 24 Feb 14
* - 24 Feb 2014
- Added descriptions of new fields to the :ref:`Wiki_Data` chapter.
* - 21 Feb 14
* - 21 Feb 2014
- Added descriptions of new fields to the :ref:`Discussion Forums Data` chapter.
* - 14 Feb 14
* - 14 Feb 2014
- Added the ``seek_video`` and ``speed_change_video`` event types to the :ref:`Tracking Logs` chapter.
......@@ -100,6 +100,7 @@ The following tables store data gathered during site registration and course enr
* :ref:`auth_user`
* :ref:`auth_userprofile`
* :ref:`student_courseenrollment`
* :ref:`user_api_usercoursetag`
* :ref:`user_id_map`
.. _auth_user:
......@@ -602,6 +603,71 @@ mode
**History**: All enrollments prior to 20 Aug 2013 are "honor".
.. _user_api_usercoursetag:
============================================
Columns in the user_api_usercoursetag Table
============================================
This table uses key-value pairs to store metadata about a specific student's involvement in a specific course. For example, for a course that assigns students to groups randomly for A/B testing, a row in this table identifies the student's assignment to a partition and group.
**History**: Added 7 Mar 2014.
.. need a sample header and row from a data package when available
The ``user_api_usercoursetag`` table has the following columns:
.. list-table::
:widths: 15 15 15 15
:header-rows: 1
* - Column
- Type
- Null
- Key
* - user_id
- int(11)
- NO
- PRI
* - course_id
- varchar(255)
- NO
-
* - key
- varchar(255)
- NO
-
* - value
- textfield
- NO
-
.. need type, null, key for each one
---------
user_id
---------
The student's ID in ``auth_user.id``.
-----------
course_id
-----------
The course identifier, in the format {org}/{course}/{run} (for example, ``MITx/6.002x/2012_Fall``).
----
key
----
Identifies an attribute of the course.
For example, for a course that includes modules that are set up to perform A/B testing, the value in this column identifies a partition, or type of experiment. The key for the partition is in the format ``xblock.partition_service.partition_ID``, where ID is an integer.
------
value
------
The content for the key that is set for a student.
For example, for a course that includes modules that are set up to perform A/B testing, this column stores the group ID of the particular group the student is assigned to within the partition.
.. _user_id_map:
==================================
......@@ -883,7 +949,7 @@ done
-----------
course_id
-----------
The course that this row applies to, represented in the format org/course/run (for example, ``MITx/6.002x/2012_Fall``). The same course content (same ``module_id``) can be used in different courses, and a student's state needs to be tracked separately for each course.
The course that this row applies to, represented in the format {org}/{course}/{run} (for example, ``MITx/6.002x/2012_Fall``). The same course content (same ``module_id``) can be used in different courses, and a student's state needs to be tracked separately for each course.
.. _Certificates:
......
.. _Tracking Logs:
######################
Tracking Logs
######################
This chapter provides reference information about the event data that is delivered in data packages. Events are initiated by interactions with the courseware and the Instructor Dashboard in the LMS, and are stored in JSON documents. In the data package, event data is delivered in a log file.
The sections in this chapter provide:
The sections in this chapter describe:
* A :ref:`sample_events`.
* :ref:`common` that are included in the JSON document of every event type.
......@@ -20,7 +19,7 @@ The sections in this chapter provide:
Sample Event
*************************
A sample event from an edX.log file follows. The JSON documents that include the event data are compressed before they are added to the log file, so they appear in this compact format.
A sample event from an edX.log file follows. The JSON documents that include the event data are included in the log file as raw data, so they appear in this compact format.
.. code-block:: json
......@@ -132,7 +131,6 @@ If you use a JSON formatter to "pretty print" this event, a version that is more
"username": "AAAAAAAAAA"
}
.. _common:
********************
......@@ -149,11 +147,17 @@ This section contains a table of the JSON fields that are common to the schema d
| ``context`` | For all event types, identifies the course that generated | string/JSON | Contains these common member |
| | the event, the organization that lists the course, and the | | fields: |
| | individual who is performing the action. | | ``course_id`` |
| | Also contains member fields that apply to specific event | | ``org_id`` |
| | types only: see the descriptions for each event type. | | ``user_id`` |
| | | | ``org_id`` |
| | ``course_user_tags`` contains a dictionary with the key(s) | | ``user_id`` |
| | and value(s) from the ``user_api_usercoursetag`` table | | ``course_user_tags`` |
| | for the user. See :ref:`user_api_usercoursetag`. | | |
| | | | These fields are blank if values |
| | Also contains member fields that apply to specific event | | cannot be determined. |
| | types only: see the description for each event type. | | |
| | | | |
| | **History**: Added 23 Oct 2013; ``user_id`` added | | These fields are blank if values |
| | 6 Nov 2013. Other fields may duplicate this data. | | cannot be determined. |
| | **History**: Added 23 Oct 2013; ``user_id`` added | | |
| | 6 Nov 2013. Other event fields may duplicate this data. | | |
| | ``course_user_tags`` added 12 Mar 2014. | | |
+---------------------------+-------------------------------------------------------------+-------------+------------------------------------+
| ``event`` | Specifics of the triggered event. | string/JSON | |
+---------------------------+-------------------------------------------------------------+-------------+------------------------------------+
......@@ -161,7 +165,7 @@ This section contains a table of the JSON fields that are common to the schema d
| | browser or on the server. | | |
+---------------------------+-------------------------------------------------------------+-------------+------------------------------------+
| ``event_type`` | The type of event triggered. Values depend on | string | For descriptions of member fields, |
| | ``event_source`` | | see the event type descriptions |
| | ``event_source``. | | see the event type descriptions |
| | | | that follow. |
+---------------------------+-------------------------------------------------------------+-------------+------------------------------------+
| ``ip`` | IP address of the user who triggered the event. | string | |
......@@ -195,7 +199,9 @@ The Student Event Type table lists the event types that are logged for interacti
* :ref:`ora`
A description follows for each event type that includes what each event type represents, which component it originates from, and what ``event`` fields it contains. The ``event_source`` field from the "Common Fields" table above distinguishes between events that originated in the browser (in javascript) and events that originated on the server (during the processing of a request).
* :ref:`AB_Event_Types`
The descriptions that follow include what each event type represents, which component it originates from, and what ``event`` fields it contains. The ``event_source`` field from the "Common Fields" table above distinguishes between events that originate in the browser (in javascript) and events that originate on the server (during the processing of a request).
.. _navigational:
......@@ -217,7 +223,7 @@ These event types are fired when a user selects a navigational control.
**Event Source**: Browser
``event`` **Fields**: All of the navigational event types have the same fields.
``event`` **Fields**: These navigational event types all have the same fields.
+--------------------+---------------+---------------------------------------------------------------------+
| Field | Type | Details |
......@@ -261,10 +267,10 @@ These event types can fire when a user works with a video.
``pause_video``, ``play_video``
---------------------------------
* The ``play_video`` event type is fired on video play.
* The ``pause_video`` event type is fired on video pause.
* The ``play_video`` event type is fired on video play.
``event`` **Fields**: These event types have the same ``event`` fields.
+---------------------+---------------+---------------------------------------------------------------------+
......@@ -327,7 +333,7 @@ The ``speed_change_video`` event is fired when a user selects a different playin
PDF Interaction Event Types
==============================
The ``book`` event type is fired when a user is reading a PDF book.
The ``book`` event type is fired when a user is viewing a PDF book.
**Component**: PDF Viewer
......@@ -364,7 +370,7 @@ Problem Interaction Event Types
``event`` **Fields**: The ``event`` field contains the values of all input fields from the problem being checked, styled as GET parameters.
-----------------------------
``problem_check`` (Server)
``problem_check`` (Server)
-----------------------------
The server fires ``problem_check`` events when a problem is successfully checked.
......@@ -375,7 +381,7 @@ The server fires ``problem_check`` events when a problem is successfully checked
**History**:
* The ``submission`` dictionary was added to the ``event`` field, and ``module`` was added to the ``context`` field, on 5 Mar 2014.
* On 5 Mar 2014, the ``submission`` dictionary was added to the ``event`` field and ``module`` was added to the ``context`` field.
* Prior to 15 Oct 2013, this event type was named ``save_problem_check``.
......@@ -481,16 +487,20 @@ The server fires ``problem_check_fail`` events when a problem cannot be checked
**Event Source**: Server
**History**: Prior to 15 Oct 2013, this event type was named ``save_problem_check_fail``.
``event`` **Fields**:
+---------------------+---------------+---------------------------------------------------------------------+
| Field | Type | Details |
+=====================+===============+=====================================================================+
| ``state`` | string / JSON | Current problem state. |
+---------------------+---------------+---------------------------------------------------------------------+
| ``problem_id`` | string | ID of the problem being checked. |
+---------------------+---------------+---------------------------------------------------------------------+
| ``answers`` | dict | |
+---------------------+---------------+---------------------------------------------------------------------+
| ``failure`` | string | `'closed'`, `'unreset'` |
| ``failure`` | string | 'closed', 'unreset' |
+---------------------+---------------+---------------------------------------------------------------------+
-----------------------------
......@@ -522,7 +532,7 @@ The server fires ``problem_rescore`` events when a problem is successfully resco
+=====================+===============+=====================================================================+
| ``state`` | string / JSON | Current problem state. |
+---------------------+---------------+---------------------------------------------------------------------+
| ``problem_id`` | string | ID of the problem being checked. |
| ``problem_id`` | string | ID of the problem being rescored. |
+---------------------+---------------+---------------------------------------------------------------------+
| ``orig_score`` | integer | |
+---------------------+---------------+---------------------------------------------------------------------+
......@@ -565,7 +575,7 @@ The server fires ``problem_rescore_fail`` events when a problem cannot be succes
``problem_save``
-----------------------------
``problem_show`` fires when a problem is saved.
``problem_save`` fires when a problem is saved.
**Component**: Capa Module
......@@ -637,19 +647,19 @@ The server fires ``problem_rescore_fail`` events when a problem cannot be succes
+---------------------+---------------+---------------------------------------------------------------------+
------------------------------------------------
``show_answer`` or ``showanswer``
``show_answer``
------------------------------------------------
Server-side event which displays the answer to a problem.
**History**: The original name for this event type was ``showanswer``.
.. **Question** is that correct?
**Component**: Capa Module
**Event Source**: Server
**History**: The original name for this event type was ``showanswer``.
.. **Question** is this renaming info correct?
``event`` **Fields**:
+---------------------+---------------+---------------------------------------------------------------------+
......@@ -817,6 +827,68 @@ The ``staff_grading_hide_question`` and ``staff_grading_show_question`` event ty
| ``location`` | string | The location of the question whose prompt is being shown or hidden. |
+---------------------+---------------+---------------------------------------------------------------------+
.. _AB_Event_Types:
==========================
A/B Testing Event Types
==========================
Course authors can configure course content to present modules that contain other modules. For example, a parent module can include two child modules with content that differs in some way for comparison testing. When a student navigates to a module that is set up for A/B testing in this way, the student is randomly assigned to a group and shown only one of the child modules.
* Internally, a *partition* defines the type of experiment: between video and text, for example. A course can include any number of modules with the same partition, or experiment type.
* For each partition, students are randomly assigned to a *group*. The group determines which content, either video or text in this example, is shown by every module with that partitioning.
The event types that follow apply to modules that are set up to randomly assign students to groups so that different content can be shown to the different groups.
**History**: These event types were added on 12 Mar 2014.
----------------------------------
``assigned_user_to_partition``
----------------------------------
When a student views a module that is set up to test different child modules, the server checks the ``user_api_usercoursetag`` table for the student's assignment to the relevant partition, and to a group for that partition. The partition ID is the ``user_api_usercoursetag.key`` and the group ID is the ``user_api_usercoursetag.value``. If the student does not yet have an assignment, the server fires an ``assigned_user_to_partition`` event and adds a row to the ``user_api_usercoursetag`` table for the student. See :ref:`user_api_usercoursetag`.
.. note:: After this event fires, the common ``context`` field in all subsequent events includes a ``course_user_tags`` member field with the student's assigned partition and group.
**Component**: Split Test
**Event Source**: Browser
``event`` **Fields**:
+---------------------+---------------+---------------------------------------------------------------------+
| Field | Type | Details |
+=====================+===============+=====================================================================+
| ``group_id`` | integer | Identifier of the group. |
+---------------------+---------------+---------------------------------------------------------------------+
| ``group_name`` | string | Name of the group. |
+---------------------+---------------+---------------------------------------------------------------------+
| ``partition_id`` | integer | Identifier for the partition, in the format |
| | | ``xblock.partition_service.partition_ID`` where ID is an integer. |
+---------------------+---------------+---------------------------------------------------------------------+
| ``partition_name`` | string | Name of the partition. |
+---------------------+---------------+---------------------------------------------------------------------+
----------------------------------
``child_render``
----------------------------------
When a student views a module that is set up to test different content using child modules, a ``child_render`` event fires to identify the child module that is shown to the student.
**Component**: Split Test
**Event Source**: Server
``event`` **Fields**:
+---------------------+---------------+---------------------------------------------------------------------+
| Field | Type | Details |
+=====================+===============+=====================================================================+
| ``child-id`` | string | ID of the module that displays to the student. |
+---------------------+---------------+---------------------------------------------------------------------+
.. this might be renamed to child_id
.. _Instructor_Event_Types:
*************************
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment