mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
change to 0.9.15, finish amf0 utest
This commit is contained in:
parent
9521fbfaaa
commit
387be8fa3b
3 changed files with 155 additions and 9 deletions
|
@ -31,7 +31,7 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
// current release version
|
// current release version
|
||||||
#define VERSION_MAJOR "0"
|
#define VERSION_MAJOR "0"
|
||||||
#define VERSION_MINOR "9"
|
#define VERSION_MINOR "9"
|
||||||
#define VERSION_REVISION "14"
|
#define VERSION_REVISION "15"
|
||||||
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
|
#define RTMP_SIG_SRS_VERSION VERSION_MAJOR"."VERSION_MINOR"."VERSION_REVISION
|
||||||
// server info.
|
// server info.
|
||||||
#define RTMP_SIG_SRS_KEY "srs"
|
#define RTMP_SIG_SRS_KEY "srs"
|
||||||
|
|
|
@ -1174,14 +1174,15 @@ int srs_amf0_read_utf8(SrsStream* stream, string& value)
|
||||||
// support utf8-1 only
|
// support utf8-1 only
|
||||||
// 1.3.1 Strings and UTF-8
|
// 1.3.1 Strings and UTF-8
|
||||||
// UTF8-1 = %x00-7F
|
// UTF8-1 = %x00-7F
|
||||||
for (int i = 0; i < len; i++) {
|
// TODO: support other utf-8 strings
|
||||||
|
/*for (int i = 0; i < len; i++) {
|
||||||
char ch = *(str.data() + i);
|
char ch = *(str.data() + i);
|
||||||
if ((ch & 0x80) != 0) {
|
if ((ch & 0x80) != 0) {
|
||||||
ret = ERROR_RTMP_AMF0_DECODE;
|
ret = ERROR_RTMP_AMF0_DECODE;
|
||||||
srs_error("ignored. only support utf8-1, 0x00-0x7F, actual is %#x. ret=%d", (int)ch, ret);
|
srs_error("ignored. only support utf8-1, 0x00-0x7F, actual is %#x. ret=%d", (int)ch, ret);
|
||||||
ret = ERROR_SUCCESS;
|
ret = ERROR_SUCCESS;
|
||||||
}
|
}
|
||||||
}
|
}*/
|
||||||
|
|
||||||
value = str;
|
value = str;
|
||||||
srs_verbose("amf0 read string data success. str=%s", str.c_str());
|
srs_verbose("amf0 read string data success. str=%s", str.c_str());
|
||||||
|
|
|
@ -22,11 +22,156 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
#include <srs_utest_amf0.hpp>
|
#include <srs_utest_amf0.hpp>
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
#include <srs_core_autofree.hpp>
|
#include <srs_core_autofree.hpp>
|
||||||
#include <srs_kernel_error.hpp>
|
#include <srs_kernel_error.hpp>
|
||||||
#include <srs_kernel_stream.hpp>
|
#include <srs_kernel_stream.hpp>
|
||||||
|
|
||||||
VOID TEST(AMF0Test, Size)
|
// user scenario: coding and decoding with amf0
|
||||||
|
VOID TEST(AMF0Test, ScenarioMain)
|
||||||
|
{
|
||||||
|
// coded amf0 object
|
||||||
|
int nb_bytes = 0;
|
||||||
|
char* bytes = NULL;
|
||||||
|
|
||||||
|
// coding data to binaries by amf0
|
||||||
|
// for example, send connect app response to client.
|
||||||
|
if (true) {
|
||||||
|
// props: object
|
||||||
|
// fmsVer: string
|
||||||
|
// capabilities: number
|
||||||
|
// mode: number
|
||||||
|
// info: object
|
||||||
|
// level: string
|
||||||
|
// code: string
|
||||||
|
// descrption: string
|
||||||
|
// objectEncoding: number
|
||||||
|
// data: array
|
||||||
|
// version: string
|
||||||
|
// srs_sig: string
|
||||||
|
SrsAmf0Object* props = SrsAmf0Any::object();
|
||||||
|
SrsAutoFree(SrsAmf0Object, props, false);
|
||||||
|
props->set("fmsVer", SrsAmf0Any::str("FMS/3,5,3,888"));
|
||||||
|
props->set("capabilities", SrsAmf0Any::number(253));
|
||||||
|
props->set("mode", SrsAmf0Any::number(123));
|
||||||
|
|
||||||
|
SrsAmf0Object* info = SrsAmf0Any::object();
|
||||||
|
SrsAutoFree(SrsAmf0Object, info, false);
|
||||||
|
info->set("level", SrsAmf0Any::str("info"));
|
||||||
|
info->set("code", SrsAmf0Any::str("NetStream.Connnect.Success"));
|
||||||
|
info->set("descrption", SrsAmf0Any::str("connected"));
|
||||||
|
info->set("objectEncoding", SrsAmf0Any::number(3));
|
||||||
|
|
||||||
|
SrsAmf0EcmaArray* data = SrsAmf0Any::ecma_array();
|
||||||
|
info->set("data", data);
|
||||||
|
data->set("version", SrsAmf0Any::str("FMS/3,5,3,888"));
|
||||||
|
data->set("srs_sig", SrsAmf0Any::str("srs"));
|
||||||
|
|
||||||
|
// buf store the serialized props/info
|
||||||
|
nb_bytes = props->total_size() + info->total_size();
|
||||||
|
ASSERT_GT(nb_bytes, 0);
|
||||||
|
bytes = new char[nb_bytes];
|
||||||
|
|
||||||
|
// use SrsStream to write props/info to binary buf.
|
||||||
|
SrsStream s;
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, s.initialize(bytes, nb_bytes));
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, props->write(&s));
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, info->write(&s));
|
||||||
|
EXPECT_TRUE(s.empty());
|
||||||
|
|
||||||
|
// now, user can use the buf
|
||||||
|
EXPECT_EQ(0x03, bytes[0]);
|
||||||
|
EXPECT_EQ(0x09, bytes[nb_bytes - 1]);
|
||||||
|
}
|
||||||
|
SrsAutoFree(char, bytes, true);
|
||||||
|
|
||||||
|
// decoding amf0 object from bytes
|
||||||
|
// when user know the schema
|
||||||
|
if (true) {
|
||||||
|
ASSERT_TRUE(NULL != bytes);
|
||||||
|
|
||||||
|
// use SrsStream to assist amf0 object to read from bytes.
|
||||||
|
SrsStream s;
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, s.initialize(bytes, nb_bytes));
|
||||||
|
|
||||||
|
// decoding
|
||||||
|
// if user know the schema, for instance, it's an amf0 object,
|
||||||
|
// user can use specified object to decoding.
|
||||||
|
SrsAmf0Object* props = SrsAmf0Any::object();
|
||||||
|
SrsAutoFree(SrsAmf0Object, props, false);
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, props->read(&s));
|
||||||
|
|
||||||
|
// user can use specified object to decoding.
|
||||||
|
SrsAmf0Object* info = SrsAmf0Any::object();
|
||||||
|
SrsAutoFree(SrsAmf0Object, info, false);
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, info->read(&s));
|
||||||
|
|
||||||
|
// use the decoded data.
|
||||||
|
SrsAmf0Any* prop = NULL;
|
||||||
|
|
||||||
|
// if user requires specified property, use ensure of amf0 object
|
||||||
|
EXPECT_TRUE(NULL != (prop = props->ensure_property_string("fmsVer")));
|
||||||
|
// the property can assert to string.
|
||||||
|
ASSERT_TRUE(prop->is_string());
|
||||||
|
// get the prop string value.
|
||||||
|
EXPECT_STREQ("FMS/3,5,3,888", prop->to_str().c_str());
|
||||||
|
|
||||||
|
// get other type property value
|
||||||
|
EXPECT_TRUE(NULL != (prop = info->get_property("data")));
|
||||||
|
// we cannot assert the property is ecma array
|
||||||
|
if (prop->is_ecma_array()) {
|
||||||
|
SrsAmf0EcmaArray* data = prop->to_ecma_array();
|
||||||
|
// it must be a ecma array.
|
||||||
|
ASSERT_TRUE(NULL != data);
|
||||||
|
|
||||||
|
// get property of array
|
||||||
|
EXPECT_TRUE(NULL != (prop = data->ensure_property_string("srs_sig")));
|
||||||
|
ASSERT_TRUE(prop->is_string());
|
||||||
|
EXPECT_STREQ("srs", prop->to_str().c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
// confidence about the schema
|
||||||
|
EXPECT_TRUE(NULL != (prop = info->ensure_property_string("level")));
|
||||||
|
ASSERT_TRUE(prop->is_string());
|
||||||
|
EXPECT_STREQ("info", prop->to_str().c_str());
|
||||||
|
}
|
||||||
|
|
||||||
|
// use any to decoding it,
|
||||||
|
// if user donot know the schema
|
||||||
|
if (true) {
|
||||||
|
ASSERT_TRUE(NULL != bytes);
|
||||||
|
|
||||||
|
// use SrsStream to assist amf0 object to read from bytes.
|
||||||
|
SrsStream s;
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, s.initialize(bytes, nb_bytes));
|
||||||
|
|
||||||
|
// decoding a amf0 any, for user donot know
|
||||||
|
SrsAmf0Any* any = NULL;
|
||||||
|
EXPECT_EQ(ERROR_SUCCESS, srs_amf0_read_any(&s, &any));
|
||||||
|
SrsAutoFree(SrsAmf0Any, any, false);
|
||||||
|
|
||||||
|
// for amf0 object
|
||||||
|
if (any->is_object()) {
|
||||||
|
SrsAmf0Object* obj = any->to_object();
|
||||||
|
ASSERT_TRUE(NULL != obj);
|
||||||
|
|
||||||
|
// use foreach to process properties
|
||||||
|
for (int i = 0; i < obj->count(); ++i) {
|
||||||
|
string name = obj->key_at(i);
|
||||||
|
SrsAmf0Any* value = obj->value_at(i);
|
||||||
|
|
||||||
|
// use the property name
|
||||||
|
EXPECT_TRUE("" != name);
|
||||||
|
// use the property value
|
||||||
|
EXPECT_TRUE(NULL != value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
VOID TEST(AMF0Test, ApiSize)
|
||||||
{
|
{
|
||||||
// size of elem
|
// size of elem
|
||||||
EXPECT_EQ(2+6, SrsAmf0Size::utf8("winlin"));
|
EXPECT_EQ(2+6, SrsAmf0Size::utf8("winlin"));
|
||||||
|
@ -282,7 +427,7 @@ VOID TEST(AMF0Test, Size)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID TEST(AMF0Test, AnyElem)
|
VOID TEST(AMF0Test, ApiAnyElem)
|
||||||
{
|
{
|
||||||
SrsAmf0Any* o = NULL;
|
SrsAmf0Any* o = NULL;
|
||||||
|
|
||||||
|
@ -365,7 +510,7 @@ VOID TEST(AMF0Test, AnyElem)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID TEST(AMF0Test, AnyIO)
|
VOID TEST(AMF0Test, ApiAnyIO)
|
||||||
{
|
{
|
||||||
SrsStream s;
|
SrsStream s;
|
||||||
SrsAmf0Any* o = NULL;
|
SrsAmf0Any* o = NULL;
|
||||||
|
@ -675,7 +820,7 @@ VOID TEST(AMF0Test, AnyIO)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID TEST(AMF0Test, AnyAssert)
|
VOID TEST(AMF0Test, ApiAnyAssert)
|
||||||
{
|
{
|
||||||
SrsStream s;
|
SrsStream s;
|
||||||
SrsAmf0Any* o = NULL;
|
SrsAmf0Any* o = NULL;
|
||||||
|
@ -749,7 +894,7 @@ VOID TEST(AMF0Test, AnyAssert)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID TEST(AMF0Test, ObjectProps)
|
VOID TEST(AMF0Test, ApiObjectProps)
|
||||||
{
|
{
|
||||||
SrsAmf0Object* o = NULL;
|
SrsAmf0Object* o = NULL;
|
||||||
|
|
||||||
|
@ -827,7 +972,7 @@ VOID TEST(AMF0Test, ObjectProps)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
VOID TEST(AMF0Test, EcmaArrayProps)
|
VOID TEST(AMF0Test, ApiEcmaArrayProps)
|
||||||
{
|
{
|
||||||
SrsAmf0EcmaArray* o = NULL;
|
SrsAmf0EcmaArray* o = NULL;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue