代码拉取完成,页面将自动刷新
package python3
import (
"testing"
"github.com/stretchr/testify/assert"
)
func TestUnicodeNew(t *testing.T) {
Py_Initialize()
s := PyUnicode_New(20, 'z')
assert.NotNil(t, s)
defer s.DecRef()
}
func TestUnicodeFromString(t *testing.T) {
Py_Initialize()
u := PyUnicode_FromString("aaa")
assert.True(t, PyUnicode_Check(u))
assert.True(t, PyUnicode_CheckExact(u))
defer u.DecRef()
assert.Equal(t, 3, PyUnicode_GetLength(u))
}
func TestUnicodeFromEncodedObject(t *testing.T) {
Py_Initialize()
b := PyBytes_FromString("bbb")
assert.NotNil(t, b)
defer b.DecRef()
ub := PyUnicode_FromEncodedObject(b, "utf-8", "strict")
assert.NotNil(t, ub)
defer ub.DecRef()
}
func TestUnicodeChar(t *testing.T) {
Py_Initialize()
u := PyUnicode_FromString("aaa")
assert.True(t, PyUnicode_Check(u))
assert.True(t, PyUnicode_CheckExact(u))
defer u.DecRef()
assert.Equal(t, 0, PyUnicode_WriteChar(u, 1, 'd'))
assert.Equal(t, 'd', PyUnicode_ReadChar(u, 1))
}
func TestUnicodeFill(t *testing.T) {
Py_Initialize()
u := PyUnicode_FromString("aaa")
assert.True(t, PyUnicode_Check(u))
assert.True(t, PyUnicode_CheckExact(u))
defer u.DecRef()
assert.Equal(t, 3, PyUnicode_Fill(u, 0, 3, 'c'))
assert.Equal(t, "ccc", PyUnicode_AsUTF8(u))
}
func TestUnicodeCopyCharacters(t *testing.T) {
Py_Initialize()
u := PyUnicode_FromString("aaa")
assert.True(t, PyUnicode_Check(u))
assert.True(t, PyUnicode_CheckExact(u))
defer u.DecRef()
b := PyBytes_FromString("bbb")
assert.NotNil(t, b)
defer b.DecRef()
ub := PyUnicode_FromEncodedObject(b, "utf-8", "strict")
assert.NotNil(t, ub)
defer ub.DecRef()
assert.Equal(t, 3, PyUnicode_CopyCharacters(ub, u, 0, 0, 3))
assert.Equal(t, "aaa", PyUnicode_AsUTF8(ub))
}
func TestUnicodeSubstring(t *testing.T) {
Py_Initialize()
u := PyUnicode_FromString("aaa")
assert.True(t, PyUnicode_Check(u))
assert.True(t, PyUnicode_CheckExact(u))
defer u.DecRef()
sub := PyUnicode_Substring(u, 0, 2)
assert.NotNil(t, sub)
sub.DecRef()
assert.Equal(t, "aa", PyUnicode_AsUTF8(sub))
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。